Flink+Hologres助力伊的家电商平台建设新一代实时数仓

简介:Hologres+Flink+DataWorks实时数仓新方案为伊的家业务带来了统一数据、统一服务、统一治理、统一存储的价值,真的作到了开箱即用,所见即所得!

广州伊的家网络科技有限公司是一家专一于服务女性的B2B2C电商平台,业务范围包括护肤、彩妆、养分美容食品、私人定制服装、跨境电商等领域。自2008年孵化项目,2011年5月上线天猫商城,全国8大配送中心,妍诗美、妍膳等品牌陆续成立,并于2013年上线了伊的家自主电商平台,2020年全面启动品牌升级。伊的家以互联网主动式服务营销,打造护肤老师与客户强链接关系,从上到下严格贯彻以品质及专业为基础,以社交信任作链接,以服务得到承认的经营思路,通过持续的创新和积累,成为社交电商翘楚。数据库

业务场景与痛点分析

伊的家是一家集开发、设计、运营、销售于一体一个B2B2B的电商平台,服务百万级会员以外,还同时支持上千级别经销商和代理商,业务应用多、数据量大、数据查询并发要求高。性能优化

伊的家技术部门在近3年经历了高速发展,在发展过程当中,始终坚持业务优先,为此也进行了应用整合、拆分微服务、聚合分布式应用的多种技术升级改造,目前整个部门现状分析以下:网络

架构方面:多语言、多数据源、技术升级的业务入侵问题明显;架构

数据方面:应用拆分引起的数据孤岛问题,继而形成大量的数据复制、从新建设问题;并发

应用方面:从业绩的角度出发,业务方但愿及时准确地看见业绩数据,对实时性有了较高需求;运维

效率方面:体系化的流程与工具诉求愈发强烈;分布式

成本方面:主要问题是既懂大数据又懂业务的人才招聘难,团队建设成本高微服务

伊1.png

伊的家近几年业务高速增加,数据量激增,业务复杂度也随之增大,解决在当前大数据架构之下,“人才储备难”、“业务升级受限于已有技术”、“双11活动压力大”等痛点问题已迫在眉睫。高并发

伊2.png

产品选型

伊的家技术部门对于技术升级改造的需求有很是明确清晰的定义,主要围绕关存储弹性扩缩容、查询性能优化、OLAP、学习成本、查询响应、可扩展等角度进行展开,核心关注如下3个问题:工具

1)如何快速完成数据清洗

2)如何快速精准完成数据校验

3)如何快速进行故障恢复处理

伊3.png

在技术选型时始终坚持“技术选型是第一辈子产力”的原则,坚信技术储备没有最好只有更好,坚信技术选型是决定能力差别化所在,坚持提升一次性把事情作对的能力,坚信开放分享、认知升级的重要性。

伊4.png

早期耶基于Hadoop、HBase、Kafaka、Azkaban、Spark、Greenplum等开源大数据产品进行了许多摸索尝试,经过性能对比最终采用了Greenplum,但最终发现Greenplum并发能力差,只适合分析场景,并不适合高并发的查询服务。

后来,在阿里云大数据计算平台团队的建议下,伊的家技术部进行了全面架构升级,整个架构由DataWorks、实时计算Flink和Hologres组成,架构简单、学习成本很是低,仅经过SQL便可轻松跑通全链路

下面将会给你们介绍,阿里云技术产品在伊的家落地的场景最佳实践

最佳实践

1、客户系统实践

伊的家原客户关系管理系统(CRM)主要基于MySQL、MQ、Canal以及自研应用组成,为支持业务系统切断式升级,技术部门自主研发了一套消息中间件,维护成本较高;基于Binlog、MQ、OLAP等产品自定义的数据开发流程过程繁琐复杂、维护成本极高,且由于系统要求数据有序对清洗的并发产生了必定的限制。

伊5.png

基于Hologres+DataWorks+实时计算Flink进行架构升级后,直接经过DataWorks数据集成将数据库数据实时写入Hologres,而后经过实时计算Flink订阅Hologres作进一步实时清洗,把结果表更新到数据库,便可直接服务业务。

总体架构清晰简单、数据精准、端到端纯实时、存储分析一体化、托管式运维、全自动工具做业,原系统15人花了3个月才完成项目上线,当前架构仅需2天即部署完成。

伊6.png

2、BI业绩系统实践

BI业绩系统也能够理解为实时GMV大屏,业务数据主要有两方面的要求:

  • 实时
  • 精准,业绩计算毫不容许出错。

原架构以下图图所示,原始数据层经过Binlog,再通过Canal套件实时写入MQ,以后根据业务域进行业务数据分层和清洗。任务调度系统更新业绩的顺序为“日-月-季度-年”,这个看似完美的方案实际存在着几个问题:

  • 实时性问题:看似实时,其实过程当中可能存在5~10分钟的延迟;
  • 并发问题:消费的并发有必定限度。
  • 运维问题:若是图中的某个环节出现问题,可能会致使系统也跟着出现问题。
  • 数据清洗时效问题:清洗脚本运行一次可能须要数分钟,这期间可能会发生许多其余事情。

伊7.png

下图为升级后的BI业绩系统新架构。经过DataWorks实时同步明细数据至Hologres,基于Hologres数据再增长一份实时计算Flink的实时ETL做业,便可完成“日-月-季度-年”数据的加工,最后基于Hologres对上层应用提供分析查询服务。整个系统纯实时调度、实时性高、秒级延迟、全SQL开发、数据校验高效。

伊8.png

3、实时应用数仓架构实践

伊的家的技术部门也一直在思考如何让应用开发人员也具有大数据开发能力,如何让大数据不只仅为大数据团队所用,还同时为应用开发团队所用。

基于实时计算FLink+Hologres+DataWorks实时数仓架构的落地,提高了数据底盘的可复用性,提升了应对业务变化的数据动态调整的灵活性,与应用团队共同构建起带数据的应用系统。

伊9.png

4、集团数仓架构实践

伊的家数仓团队服务在电商业务的同时,还须要支持集团内部业务。集团数仓平台如市场主流数仓架构、基于开源大数据体系构建,目前也已经全面升级为Hologres+实时计算Flink+DataWorks实时数仓架构。

伊10.png

伊11.png

业务价值与赋能

Hologres+实时计算Flink+DataWorks实时数仓新方案为业务上带来的价值主要以下:

  • 统一数据:一套方案就能支持完整流程,明细表、维度表等数据统1、有序
  • 统一服务:由Hologers直接提供各类线上服务,包括数据分析,数据服务等,减小接口建设。
  • 统一存储:以Hologres为统一存储,多数据源都能直接写入到Hologres,无冗余存储,节约成本
  • 统一治理:DataWorks提供统一标准、统一做业和统一监控等,为大数据开发平台提供统一治理。

从业务上来讲,新的大数据方案真的作到了开箱即用,所见即所得

伊12.png

展望将来

在大数据领域,数据规模和业务复杂性是同时制约查询性能的关键因素,在这个过程当中,惟有咱们的开发人员不断打磨本身的数据模型,当数据模型达到必定成熟度,性能问题便可迎刃而解。

最后,但愿你们拥抱技术、拥抱变化、赢在模型,数据服务业务,数据服务应用,让咱们为应用而生,为应用而战。

伊13.png

伊14.png

做者:刘松森 ,伊的家CTO,高级工程师,副教授职称,国内多所高校客座教授

本文内容由阿里云实名注册用户自发贡献,版权归原做者全部,阿里云开发者社区不拥有其著做权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。若是您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将马上删除涉嫌侵权内容。