Apache DolphinScheduler 架构演进介绍及开源经验分享 - eBay 阮文俊
引言
来自 eBay 的文俊同学在近期的上海开源大数据 Meetup 上做了十分精彩的 “Apache DolphinScheduler 的架构演进” 分享。本次分享有近 200 人参与,在线观看次数超过 2,500 次

图为现场
分享视频请参见

Apache DolphinScheduler 介绍
Apache DolphinScheduler 是一个云原生的分布式去中心化,易扩展的可视化 DAG 工作流任务调度平台。致力于解决数据处理流程中错综复杂的依赖关系,使调度系统在数据处理流程中开箱即用。DolphinScheduler 以有向无环图的方式将任务连接起来,可实时监控任务的运行状态,同时支持取消、暂停、恢复、从指定任务节点重跑等操作。
DolphinScheduler 具有以下几个优良功能特性:
Cloud Native — 支持多云/数据中心工作流管理,也支持 Kubernetes、Docker 部署和自定义任务类型,分布式调度,整体调度能力随集群规模线性增长
高可靠与高可扩展性 — 去中心化的多 Master 多 Worker 设计架构,支持服务动态上下线,自我容错与调节能力
支持多租户
丰富的使用场景 — 包括流、暂停、恢复操作,以及额外的任务类型,如 Spark、Hive、MR、Shell、Python、Flink 以及 DS 独有的子工作流、任务依赖设计,扩展点采用插件化的实现方式
简单易用 — 所有流程定义操作可视化编排,定义关键信息一目了然,一键部署
关于 DolphinSheduler 更多功能介绍和开发文档请查阅官网详细信息 https://dolphinscheduler.apache.org/zh-cn/。
架构演进过程
1.2.x 架构
DolphinScheduler 最初进入 Apache 孵化器的版本是 1.2,在这一版本中采用的架构由以下几个重要部分组成:
去中心化的 master 节点,负责工作流调度、DAG 任务切分、任务提交监控和监听其它节点健康状态等任务
去中心化的 worker 节点,负责执行任务和维护任务的生命周期等
数据库,存储工作流元数据,运行实例数据
Zookeeper,主要负责注册中心、分布式锁、任务队列等工作任务
1.2 版本基本实现了高可靠的工作流调度系统,但是也存在多个问题:
重量级的 worker,worker 节点需要负责多种任务
异步派发任务会导致任务执行延迟
由于 masker 和 worker 都需要依赖数据库,导致数据库压力大

1.3.x 架构
针对 1.2 版本存在的问题,1.3 架构进行了如下改进:
去任务队列,保证 master 节点同步派发任务,降低任务执行延迟
轻量级 worker,worker 节点只负责执行任务,单一化 worker 职责
减小数据库压力,worker 不再连接数据库
采用多任务负载均衡策略,master 根据 worker 节点资源使用情况分配任务,提高 worker 资源利用率

这些改进有效改进了 1.2 版本的缺陷,但仍存在一些问题,例如:
master 调度工作流时需要依赖分布式锁,导致工作流吞吐量难以提升
因为需要创建大量线程池,多数线程处于轮询数据库,导致 master 资源利用率低
master 轮询数据库,仍然导致数据库压力大
各组件存在耦合情况
2.0 架构
针对 1.3 版本的缺陷,2.0 架构进一步做出以下改进:
去分布式锁,对 master 进行分区编号,实现错位查询数据库,避免多个节点同时访问同一个工作流造成的冲突问题
重构 master 线程模型,对所有工作流使用统一的线程池
重构数据库中 DAG 元数据模型
彻底的插件化,所有扩展点都采用插件化实现
数据血缘关系分析
1 去分布式锁

2 重构 master 中的线程模型

SchedulerThread 负责从数据库中查询 Command 并提交到 Command Queue
DagExecuteThreadPool 从 Command Queue 中取 command,并构造 DAG实例添加到 DAG 队列,进行处理,当前 DAG 没有未执行的任务,则当前 DAG 执行结束
TaskExecuteThreadPool 提交任务给 Worker
TaskEventThread 监听任务事件队列,修改任务状态
3 彻底的插件化

所有扩展点都采用插件化实现
告警SPI
注册中心SPI
资源存储SPI
任务插件SPI
数据源SPI
……
Apache DolphinScheduler 发展方向
文俊针对 DolphinScheduler 的未来发展方向,也分享了一些看法:
系统更稳、速度更快(高吞吐、低延迟、智能化运维、高可用)
支持更多的任务集成(深度学习任务、CI/CD等其它系统集成、存储过程和数据质量任务、容器调度任务、复杂调度场景等)
轻量化 DolphinScheduler 内核,提供基础调度服务

如何参与开源贡献
最后,开发者阮文俊针对入门新手如何参与开源贡献的问题,提出了宝贵的指导意见:
从小事做起,积累开发经验
关注社区动态,积极参与讨论,更好融入社区
坚持开源精神,乐于帮助他人
保持持之以恒的开发和贡献心态
分享讲师:阮文俊,eBay 开发工程师,DolphinScheduler 深度贡献者,开源深度玩家
编辑:徐玮毅,天津大学 2018 级计算机科学与技术本科生,热爱编程,开拓进取。本文是第一次参与 DolphinScheduler 社区的开源工作,希望能逐渐积累经验,继续为社区作出更大贡献!

点击阅读原文,加入官方 Slack 讨论群 也欢迎关注推特: https://twitter.com/DolphinSchedule
Apache DolphinScheduler 架构演进介绍及开源经验分享 - eBay 阮文俊的更多相关文章
- Apache DolphinScheduler 架构演进 & Roadmap
<DataFunSummit:大数据存储架构峰会> 2021年4月17日Apache DolphinScheduler PMC chair 代立冬参与 DataFunSummit 分享&l ...
- Apache DolphinScheduler&TiDB联合Meetup | 聚焦开源生态发展下的应用开发能力
在软件开发领域有一个流行的原则:Don't Repeat Yourself(DRY),翻译过来就是:不要重复造轮子.而开源项目最基本的目的,其实就是为了不让大家重复造轮子. 尤其是在大数据这样一个高速 ...
- 新一代大数据任务调度 - Apache DolphinScheduler喜提十大开源新锐项目 & 最具人气项目
经 10000+ 开发者公开票选,20+专家评审. 10+ 主编团打分,历经数月打磨,11 月 19 日,由InfoQ 发起并组织的[2020中国技术力量年度榜单评选]结果正式揭晓. 2020 年度十 ...
- 议题征集令 | Apache DolphinScheduler Meetup 2021 来啦,议题征集正式开启!
点击上方 蓝字关注我们 社区的小伙伴们,经过精心筹备,我们很高兴地宣布,Apache DolphinScheduler Meetup 2021 将于 2021 年 11 月 27 日到来! 在 Mee ...
- 从 Airflow 到 Apache DolphinScheduler,有赞大数据开发平台的调度系统演进
点击上方 蓝字关注我们 作者 | 宋哲琦 ✎ 编 者 按 在不久前的 Apache DolphinScheduler Meetup 2021 上,有赞大数据开发平台负责人 宋哲琦 带来了平台调度系统 ...
- 本周六 Apache DolphinScheduler & Doris 将联合线上 Meetup
活动背景 2020年,大数据成为国家基建的一个重要组成,大数据在越来越多的领域展现威力.随着大数据的应用场景越来越多,大家对数据的响应速度和数据加工工作流的方便程度也提出了更高的要求.在这种背景下,相 ...
- Apache DolphinScheduler & Doris 将于本周六联合进行线上 Meetup
01 - 活动介绍 2020年,大数据成为国家基建的一个重要组成,大数据在越来越多的领域展现威力.随着大数据的应用场景越来越多,大家对数据的响应速度和数据加工工作流的方便程度也提出了更高的要求.在这种 ...
- 日均 6000+ 实例,TB 级数据流量,Apache DolphinScheduler 如何做联通医疗大数据平台的“顶梁柱”?
作者 | 胡泽康 鄞乐炜 作者简介 胡泽康 联通(广东)产业互联网公司 大数据工程师,专注于开源大数据领域,从事大数据平台研发工作 鄞乐炜 联通(广东)产业互联网公司 大数据工程师,主要从事大数据平 ...
- Apache DolphinScheduler 1.3.6 功能发布说明
参与人员 @chengshiwen.@hailin0.@wanghong1314.@ruanwenjun.@xxjingcd.@zhangguohao.@zhuangchong.@syb8535531 ...
随机推荐
- 解放双手!推荐一款 GitHub 星标 8.2k+的命令行软件管理器,非常酷炫!
小二是公司新来的实习生,之前面试的过程中对答如流,所以我非常看好他.第一天,我给他了一台新电脑,要他先在本地搭建个 Java 开发环境. 二话不说,他就开始马不停蹄地行动了.真没想到,他竟然是通过命令 ...
- 最大流&最小割&费用流模版
好久都没有搞博客了.想认真写又要准备文化课期末了. ISAP 流程: 原理就是dfs找增广路. 最基础的建反向边以便反悔就不说了. 但是记录一个dep(dis)表示层数,一开始BFS(从t开始,dis ...
- Vue出现Component template should ...
当运行vue出现错误Component template should contain exactly one root element. If you ...的时候,我们只需要将<templa ...
- CabloyJS一站式助力微信、企业微信、钉钉开发 - 微信篇
前言 现在软件开发不仅要面对前端碎片化,还要面对后端碎片化.针对前端碎片化,CabloyJS提供了pc=mobile+pad的跨端自适应方案,参见:自适应布局:pc = mobile + pad 在这 ...
- Linux离线包管理器RPM
Linux离线包管理器RPM RPM 是RedHat Package Manager(RedHat软件包管理工具). 1.rpm常用参数介绍 查看rpm是否安装 rpm -q rpm包名 [root@ ...
- php类精确验证身份证号码
<?php // check class check{ // $num为身份证号码,$checkSex:1为男,2为女,不输入为不验证 public function checkIdentity ...
- 第三章、DNS域名解析服务
DNS 1DNS简介 域名系统(英文:Domain Name System,缩写:DNS)是互联网的一项服务.它作为将域名和 IP 地址相互映射的一个分布式数据库,能够使人更方便地访问互联网.DNS ...
- mysql实现两个字段合并成一个字段查询
[需求]实现国际化I18N语言切换功能,例如菜单列表.字典等. 主要是个辅助表进行管理语言的配置: 单个字段很简单,直接通过字典配置的数据标签(key)- 表名, 数据键值(value)-表字段名[默 ...
- Mysql数据库的默认引擎
InnoDB的优势在于提供了良好的事务处理.崩溃修复能力和并发控制.缺点是读写效率较差,占用的数据空间相对较大. ①InnoDB:支持事务处理,支持外键,支持崩溃修复能力和并发控制.如果需要对事务的完 ...
- 利用MATLAB仿真最小发射功率下WSN的连通性和覆盖率
一.目的 (1)在固定节点个数的前提下,仿真求得使网络保持连通的最小通信半径(最低能级). (2)在上述节点个数和通信半径的前提下,计算随机布撒的节点的覆盖率. 二.方法描述 (1)首先假设通信半径都 ...