百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

手撕数据仓库之「ETL篇」

ccwgpt 2025-02-28 15:05 39 浏览 0 评论

导读:

a、什么场景下会使用到ETL?

b、ETL与ELT的区别是什么?

c、如何快速了解ETL开发流程?

1、ETL介绍

ETL:是英文Extract-Transform-Load的缩写,用来描述将数据从来源端经过抽取(extract)、转换(transform)、加载(load)至目的端的过程。

ETL:概念通常用在数据仓库,但其对象并不限于数据仓库,什么意思呢?就是只要有涉及到数据搬运都是源到目标的过程,如:数据库迁移(Oracle迁移到MySQL)等。

使用ETL技术可以解决以下相关场景:

1、数据分散在各个系统中需要对数据进行整合,如:(图1)非常形象。

2、数据迁移到不同的环境,如:数据库、操作系统等

3、数据处理效率非常低下,如:有的用Python处理、Java处理等

2、ETL VS ELT

ETL与ELT的最核心区别是:抽取源数据是否需要【转换】后再加载到目标

设计时需要思考的问题如:

1、数据的可追溯性

2、ETL服务器资源

3、数据库服务器资源

4、程序职责边界划分

目前业界互联网80%都是基于ELT开发,传统大型数仓都是基于ETL开发。如下:

1、基于Hadoop体系构建的数据仓库,都是基于开源工具来做数据同步(如:DataX、Sqoop、Kettle等),然后基于同步数据来做相应ETL操作。

2、基于RMDB(Teradata\PostgreSQL\Oracle\DB2\MySQL\SQL Server)构建数据仓库,都是基于ETL工具来开发设计,如:Informatica、DataStage、SSIS、Kettle等。

3、ETL开发流程


数仓ETL开发流程分别为:流程设计、概要设计、逻辑设计、代码实现、任务调度、数据质量

  • 流程设计:是对数据整体链路流程描述说明
  • 概要设计:明确数据各环节处理过程
  • 逻辑设计:源到目标映射处理关系
  • 代码实现:是逻辑代码的具体实施
  • 调度任务:任务之间依赖关系与处理流程控制
  • 数据质量:监控源与目标是否准确无误

产出:ETL开发设计文档、单元测试用例

3.1、 流程设计

涉及ETL整体流程链路,明确源到目标之间过程描述

  • 数据来源信息

明确数据源相关详细信息,数据库需说明相关信息,如:IP、端口、用户名、密码、表名称;日志需说明相关信息,如:服务器信息、目录、文件名称等

  • 数据处理过程

指源数据处理存储逻辑概念描述,而非指具体处理过程。如:数仓、DataX等

  • 数据目标输出

指数据最终输出目标,目标可能是:Hive、MySQL、ClickHouse、API、File等

3.2、概要设计

基于源数据进行分析,确定数据抽取、装载、问题环节相关策略。

  • 数据探查

数据来源分两类:一类业务数据(DB);一类行为数据(日志)。两类数据都需要对结构、字段、字段值、字段解释进行探查。

  • 表、日志结构

表结构或日志结构实际是否与文档描述一致,如:业务方说某字段在表中是唯一,但实际表结构并未设置唯一键问题;防止发生少表问题。

  • 字段

实际是否与文档描述一致,防止发生缺少字段、新加字段问题。

  • 字段值

实际检查枚举值、状态值等是否与文档描述一致,防止与业务方描述不一样问题。

  • 解释

表结构、日志结构、字段都应当有具体文档解释说明。

  • 抽取策略

确定数据抽取口径(全量、增量);明确数据提取频次(如:时、天、周、月)

  • 装载策略

确定源数据到目标表装载策略类型(如:增量、Merge、全量)

  • 问题处理

问题处理方式确定,如:执行时间过长,配置超时告警。执行出失败,邮件告警(默认)。关键核心数据配置【监控中心】电话通知告警。

3.3、逻辑设计

源到目标过程具体字段处理逻辑说明

  • 命名规范

参见:《数仓命名规范》

  • 映射关系

源数据到目标表的字段映射关系

  • 转换规则

源数据到目标表字段处理逻辑

3.4、代码实现

基于逻辑设计编写程序实现具体功能

  • 开发规范

参见:《数仓开发规范》

  • 脚本性能

程序实现需要考虑具体性能问题,性能要求如下:

层名称

性能要求

执行时间段

buf

0~1200s

0:01 ~ 1:00

ods

0~1200s

0:01 ~ 1:00

dim

0~1800s

1:01 ~ 3:00

dwd

0~1800s

1:01 ~ 3:00

dww

0~1800s

3:01 ~ 4:00

ads

0~600s

4:01 ~ 6:00

未能达到性能要求,不能上线生产环境(特殊情况需向研发负责人说明)

  • 引擎策略

根据具体业务要求采使用不同执行引擎,如:MR、Presto、Spark等

  • 单元测试

参见:《脚本测试》

3.5、调度任务

脚本开发完成后在调度系统中指定相应时间让任务运行

  • 命名规范

参见:《调度命名规范》

  • 依赖配置

配置脚本涉及到的所有前置任务依赖

  • 资源控制

合理控制任务并发数让资源合理使用,避免任务与任务之间出现资源争抢。

  • 流程控制

根据具体业务情况控制任务优先级、项目与任务之间关联关系

  • 单元测试

参见:《调度任务测试》

3.6、数据质量

确保数据从源到目标加工过程的准确性、完整性、一致性

  • 命名规范

参见:《数据质量命名规范》

  • 源与目标校验

校验源到目标数据,如:记录数、数值汇总、分维度+记录数+数值汇总校验

  • 数据交叉校验

校验源到多目标、多源到目标、相同指标跨表等数据,如:记录数、数值汇总、分维度+记录数+数值汇总校验

  • 数据趋势校验

校验目标表数据历史趋势情况,如:日、周、月、年周期环比、同比校验

  • 单元测试

参见:《数据质量测试》

4、ETL工具选型

ETL工具调研选型结合项目实际情况,主要考虑如下:

1、ETL工具是否收费(只考虑免费)

2、团队整体技术栈(比如:Java)

3、ETL工具熟练程度

4、工具社区活跃情况

5、工具文档完善程序

通过以上几点考虑,第1点就过滤了一大批收费工具,再经过筛选只剩下两款工具,分别是:DataX与Sqoop两款。它们之间的功能对比如下

功能

DataX

Sqoop

运行模式

单进程多线程

MapReduce

MySQL读写

单机压力大;读写粒度容易控制

MapReduce 模式重,写出错处理麻烦

Hive读写

单机压力大

扩展性好

文件格式

orc支持

orc不支持,可添加

分布式

不支持,可以通过调度系统规避

支持

统计信息

已有一些统计,上报需定制

没有,分布式的数据收集不方便

数据校验

在core部分有校验功能

没有,分布式的数据收集不方便

监控

社区

社区不活跃

核心部分变动很少

DataX 主要的缺点在于单机运行,而这个问题我们通过分布试调度系统规避,其他方面的功能均优于 Sqoop,最终我们选择了基于 DataX 开发。

相关推荐

css布局方案汇总(28个实例图文并茂)

简介布局在我们前端日常开发来说是非常重要的,一个好的布局能简化代码的同时还能提高网页的性能。常见的布局方法有浮动(float)布局、绝对定位(position)布局、表格布局(table)、弹性(fl...

十款免费的CSS框架加速Web开发

Pure这是Yahoo最新推出的一款CSS框架,它只有HTML和CSS,没有使用任何JavaScript语言。总大小只有4.4kb,但功能却非常丰富,支持响应式样式和各种导航、表格、表单、按钮、网格和...

Tailwind CSS 是不是目前世上最好的CSS框架?

转载说明:原创不易,未经授权,谢绝任何形式的转载今天看了一篇国外大佬对TailwindCSS的看法,在这里分享给大家,看看大家是否赞同,以下是其相关内容的整理,由于翻译水平有限,欢迎大家讨论和指...

下一代 CSS 框架:Mojo CSS,为何如此受欢迎?

TailwindCSS推出即受到广大开发者的欢迎,当前Githubstar数已达77.8k。它是一个功能类优先(utility-first)的CSS框架,它提供了一系列功能类,让开发者...

常见的几种摄影构图方式

摄影构图,是一种在摄影画面中表现结构美、形式美的方式。构图能让摄影主体更加突出,画面更加有序。所以说,构图在摄影中是非常重要的一个环节。无论是前期构图还是后期构图,摄影者都要对构图有一个比较深的了解。...

风光摄影10大构图技巧,会用构图,照片更容易好看

风光摄影10大构图技巧,会用构图,照片更容易好看先解释一下,为什么会使用构图之后,照片更容易好看?因为,构图是根据很多好看的照片,总结出来的技巧,使用这些构图技巧,就相当于站在了巨人的肩膀上,也就是用...

掌握框式构图的摄影技巧,会让摄影爱好者的作品更有魅力!

很多摄影爱好者都知道摄影构图中有个框式构图,但大多数人对框式构图的摄影技巧,却一知半解。所以摄影爱好者们有必要更全面、深入的了解,并掌握框式构图,会对你摄影水平的提高更有帮助。【欢迎点击上方关注:金立...

这个构图很简洁,但为什么不耐看?

摄影爱好者最常犯的错就是过于复杂、主体不明确,但当遇到简单的场景往往又会出现单调、不耐看的状况。为什么会这样?说白了还是观察力不够。下面是本周的摄影入围习作,我们一起来看看这些照片中主体、陪体以及背景...

初学者需要记牢的八种常用构图法

作者:冯海军摄影中,构图很关键,决定照片是否成功,所以在构图上要加以重视和推敲,虽然说构图无定法,但是也有很多的规律可循,以下列举几种常用构图,会对初学者有很大的帮助。多彩刘卫洲摄苏州姑苏俱乐部(...

构图这件事不难!掌握14种构图模式就稳了

如果说视觉元素是视觉信息的载体,那么构图就是视觉元素的载体。没有适当形式的构图对视觉元素有机、有序地承载,平面设计将无法传达预定的设计意图和视觉信息。因此,对于平面设计而言,构图是平面设计不可或缺的重...

框架构图如何使用?

1分钟教你用手机拍大片。今天我们利用框架构图,在不同的运镜方法下拍摄。·首先将手机贴近地面,拍摄人物走过的画面。·然后利用3D效果的背景衬托,将手机贴近地面,以低角度仰拍人物。·最后我们用高清画质来呈...

面构图的5种超实用的构图形式 前景构图,框架构图,填充构图

面构图的5种超实用的构图形式。为什么有的人拍摄的照片好看又舒适?仔细观察会发现他们善用构图。大家好,今天带大家了解摄影中5种超实用的面构图形式。·一、前景构图。前景是构图中的神奇要素,可以提升照片的表...

一看就懂!跟着马格南的大师学构图

马格南图片社是迄今为止全球最重要的摄影图片社,其网站包涵了太多经典的名字和照片。细细品味这些经典图片,能够学到很多有用的构图手法。跟着大师走,总不会错吧?前后景的运用这似乎是非常常见的一种手法,仔细看...

这才是框架构图,有想法!能给你启发么?

框架构图大家并不陌生,但并不是有一个框就行了。框架构图用得不好,就很死板生硬,给人感觉很假。如果你理解透了,拍出的作品不会单调。今天就给大家分享一下框架构图,你看看有哪些妙用?1.广角与长焦的应用长焦...

7B小模型写好学术论文,新框架告别AI引用幻觉

ScholarCopilot团队投稿量子位|公众号QbitAI学术写作通常需要花费大量精力查询文献引用,而以ChatGPT、GPT-4等为代表的通用大语言模型(LLM)虽然能够生成流畅文本,但...

取消回复欢迎 发表评论: