分享

Azkaban与Oozie详细对比

阿飞 2019-6-20 21:09:12 发表于 总结型 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 4114
问题导读
1.Azkaban与Oozie功能上有什么相同点?
2.定义上有什么不同?
3.定时上有什么不同?


AzkabanOozie对比
  对市面上最流行的两种调度器,给出以下详细对比。知名度比较高的应该是Apache Oozie,但是其配置工作流的过程是编写大量的XML配置,而且代码复杂度比较高,不易于二次开发。ooize相比azkaban是一个重量级的任务调度系统,功能全面,但配置使用也更复杂。如果可以不在意某些功能的缺失,轻量级调度器azkaban是很不错的候选对象。
从功能上来对比
  两者均可以调度linux命令、mapreduce、spark、pig、java、hive、java程序、脚本工作流任务
  两者均可以定时执行工作流任务
从工作流定义上来对比
  1、Azkaban使用Properties文件定义工作流
  2、Oozie使用XML文件定义工作流
从工作流传参上来对比
  1、Azkaban支持直接传参,例如${input}
  2、Oozie支持参数和EL表达式,例如${fs:dirSize(myInputDir)}
从定时执行上来对比
  1、Azkaban的定时执行任务是基于时间的
  2、Oozie的定时执行任务基于时间和输入数据
从资源管理上来对比
  1、Azkaban有较严格的权限控制,如用户对工作流进行读/写/执行等操作
  2、Oozie暂无严格的权限控制
从工作流执行上来对比
  1、Azkaban有三种运行模式:
    1.1、solo server mode:最简单的模式,数据库内置的H2数据库,管理服务器和执行服务器都在一个进程中运行,任务量不大项目可以采用此模式。
    1.2、 two server mode:数据库为mysql,管理服务器和执行服务器在不同进程,这种模式下,管理服务器和执行服务器互不影响
    1.3 、multiple executor mode:该模式下,执行服务器和管理服务器在不同主机上,且执行服务器可以有多个
    我这次采用第二种模式,管理服务器、执行服务器分进程,但在同一台主机上。
  2、Oozie作为工作流服务器运行,支持多用户和多工作流


从工作流管理上来对比
  1、Azkaban支持浏览器以及ajax方式操作工作流
  2、Oozie支持命令行、HTTP REST、Java API、浏览器操作工作流


另一版本区别:
  两者在功能方面大致相同,只是Oozie底层在提交Hadoop Spark作业是通过org.apache.hadoop的封装好的接口进行提交,而Azkaban可以直接操作shell语句。在安全性上可能Oozie会比较好。
  工作流定义:Oozie是通过xml定义的而Azkaban为properties来定义。
  部署过程:  Oozie的部署太虐心了。有点难。同时它是从Yarn上拉任务日志。
        Azkaban中如果有任务出现失败,只要进程有效执行,那么任务就算执行成功,这是BUG,但是Oozie能有效的检测任务的成功与失败。
  操作工作流:Azkaban使用Web操作。Oozie支持Web,RestApi,Java API操作。
  权限控制:   Oozie基本无权限控制,Azkaban有较完善的权限控制,入用户对工作流读写执行操作。
        Oozie的action主要运行在hadoop中而Azkaban的actions运行在Azkaban的服务器中。
  记录workflow的状态:Azkaban将正在执行的workflow状态保存在内存中,Oozie将其保存在Mysql中。
  出现失败的情况:Azkaban会丢失所有的工作流,但是Oozie可以在继续失败的工作流运行。





没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条