Dataworks实战5-数据集成之技术选型

开始之前,先聊下企业数据的整体架构吧。一般来说,业务系统的数据库有较大的生产压力,大多数的做法是在企业生产库后会追加1到2个只读库,负责实时同步主库数据。业务系统写入到只读库,查询数据从从库。同时为了减轻成本压力,从库不提供binlog日志能力。

阿里巴巴的Dataworks作为一站式数据开发和数据治理的PASS平台,提供多样的数据集成能力,甚至提供了数据集成的解决方案。为完成数仓的ODS层的建设,存在离线全量ETL、离线增量+离线全量的ETL、实时增量+离线全量ETL、实时增量ETL4种方式。这里我们从技术上进行简单拆解,最终选择一个较为合适的方案,为简化起见我们的源端是RDS,即mysql数据库。

离线全量ETL:即使用Dataworks离线集成方式,配置源端mysql通过每日将全量数据抽取,并重写到ODS表,这种方式也叫"直连"方式。通过直连源端(一般都会选择从库-.-,没有从库的话请运维同事构建吧,主库拉挂了就可以祭天了)的方式,对于一般小表来说(即整体看该表整体数据量比较固定,日增量较少,如组织架构表)这种方式是可行的,且操作简单。遗憾的是:每日固定时间拉取的表数据,严格来说并不是某一个时间点的实际真是快照。如定时每天00:00:00同步数据,但实际任务调度时会因调度资源争夺等原因造成数据同步延迟(0点存在大量数据同步任务),实际落地到ODS的数据并非是00:00:00的快照。同时由于ODS数据同步的延迟,导致下游任务会停滞一段时间,数据的计算结果也会延迟一定时间,使用该方式之前需要从业务角度综合分析。对于大表来说,该方式有点慢性自杀的感觉,数据同步慢,下游计算延迟,拉挂了只读库会不会祭天我不知道,我只知道工作还得做,数据计算还得补回来,怎么解决呢?可以试试使用“离线增量+全量的ETL”的方式。

离线增量+离线全量的ETL:在特定情况下,如解析FTP文件日志、TableStore增量日志时该方案是最佳方案,也可以处理关系型数据库RDS的场景,如对大表(如订单表,每天增量100w+)可以考虑首次进行数据的全量同步到MaxCompute里的全量表table_full,后续接入每日增量的数据同步到MaxCompute的增量表table_inc,在MaxCompute里完成数据合并并重写到table_full的最新分区里。具体实践:源端Mysql定义modify_time,数据每次修改会插入时都会更新该字段。定时抽取源端数据时增加过滤条件modify_time>start_time  and modify_time<end_time将ETL的数据写入ODS增量表的分区里,再与ODS全量表最新分区数据进行合并,并重新写入到一个新的分区数据里。遗憾的是:该方式对于源库来说相当于每次扫描一次全表(可以使用索引优化)对源库也存在一定的性能压力。源端进行了历史数据的物理删除的话,数据合并时无法感知,因此需要先与业务应用系统确定数据是否存在物理删除场景。怎么解决呢?可以试试使用"实时增量+离线全量ETL"的方式。

实时增量+离线全量ETL:工作原理与上述相同。唯一不同的是通过Mysql-binlog日志的方式实时写入,通过解析binlog日志里的日志时间戳,将该时间戳转为maxcompute增量表的分区字段,并根据日志的变更类型(新增、修改、删除)、日志顺序(record_id)与全量表进行数据合并。该方案的解决了离线全量ETL中数据快照不精确的问题,并可以感知到源端数据库物理删除数据的场景,可以说是相当完美的方案了,这也是我实践的方案,后续整体会围绕该方案细说。然而该方案对数据开发人员的技术要求较高。 如何采集binlog日志,如何进行数据合并,阿里Dataworks已有了解决方案,下一章我将会细说这块"数据集成之实时增量+离线全量ETL详解"。

实时增量ETL:严格上来说,该方案是上个方案的子集,单拎出来主要基于业务考虑。数据计算场景需要获取源端完整数据的场景请使用上个方案。部分场景可能只需要关心当前增量的数据,不关心历史数据的只需要进行实时增量ETL。数据源也会多样化如mysql-binlog、rockmq等等。数据的老化策略也会不同。这块后期文章里会详细说明。




喜欢的朋友请帮忙点赞,谢谢大家!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351