Azkaban Flow 2.0 使用简介
创作时间:
作者:
@小白创作中心
Azkaban Flow 2.0 使用简介
引用
1
来源
1.
https://www.cnblogs.com/remainsu/p/azkaban-flow-20-shi-yong-jian-jie.html
本文上接《Azkaban 3.73.1 使用简介》,对Azkaban使用Flow 2.0来创建工作流做简单说明
声明:官方建议使用Flow 2.0来创建Azkaban工作流,且Flow 1.0将被弃用
一、简单的Flow
1. 新建 flow20.project 文件
- 这是一个必须的文件,且文件名固定为:flow20.project
- 文件仅一行内容:azkaban-flow-version: 2.0,其作用为表明这是Azkaban Flow 2.0的项目
touch flow20.project
echo "azkaban-flow-version: 2.0" > flow20.project
2. 新建 .flow 文件
- 这同样是一个必须的文件,且文件固定使用:.flow作为扩展名,如:money.flow、item.flow
.flow文件常用标签
标签 | 备注 |
---|---|
nodes | 这其中将包含所有要运行的job |
nodes.name | job的名字 |
nodes.type | job类型,如:command、pig |
nodes.config | 以键值对的形式,配置要执行的命令或脚本 |
config | 1. 以键值对的形式,为整个工作流定义参数 2. 定义的参数在整个Flow中均有效 3. 使用时通过 ${param_key} 引用定义好的参数 |
举例:
# 文件名:simple_1.flow
nodes:
- name: jobA
type: command
config:
command: echo "This is an echoed text by simple flow"
3. 打包
压缩上述新建的flow20.project和.flow文件 到同一个.zip文件中
- 必须是zip压缩文件,当前仅支持zip
- 所有文件必须在压缩包的根目录中,没有子目录
4. 创建Project & 上传zip & 运行Flow
具体过程略,可参考前一篇博文《Azkaban 3.73.1 简单使用》第3.3节的内容
备注:与之前不同的是,Flow的名字不再是最后一个没有依赖的job的名字,而是 .flow文件的名字
二、Job间有依赖关系的Flow
新建两个文件:flow20.project和.flow为扩展名的文件
打包zip & 上传zip & 运行
详细过程略,.flow 文件举例:
# 文件名:dependsOn.flow
nodes:
- name: jobC
type: command
config:
command: echo "This is jobC, depends on jobA and jobB"
dependsOn:
- jobA
- jobB
- name: jobA
type: command
config:
command: echo "This is jobA."
- name: jobB
type: command
config:
command: echo "This is jobB."
三、嵌入式Flow(Flow间存在依赖)
新建两个文件:flow20.project和.flow为扩展名的文件
打包zip & 上传zip & 运行
注意:依赖的Flow节点的type必须指定为:flow
详细过程略,.flow 文件举例:
config:
param.test: param_test
nodes:
- name: jobC
type: command
config:
command: echo ${param.test} "This is jobC, embedded on embedded_flow."
dependsOn:
- embedded_flow
- name: embedded_flow
type: flow
config:
param.flow.test: param_flow_test
nodes:
- name: jobB
type: command
config:
command: echo "This is jobB."
dependsOn:
- jobA
- name: jobA
type: command
config:
command: echo ${param.flow.test} "This is jobA."
说明:
config 参数无特殊意义,仅作演示使用,
与之前不同的是,flow间的依赖,所依赖的flow在web页面中的显示是如下图的样子
附录
官方文档
https://azkaban.readthedocs.io/en/latest/createFlows.html#
例子源码
热门推荐
长期跑步如何保护膝盖?
细数《星辰变》的17个境界,最高等级只有三人
膝关节疼痛,老年人长期行走的隐形杀手!专家教你如何预防和缓解
科学瘦身秘诀:合理饮食与运动双管齐下
落枕后的按摩手法
冬季吃海参进补需要多少天?全面解析帮你找到答案
腰椎盘突出怎样按摩有效
世界避孕日:中国古人如何避孕?
谢谢你,世上多了一个“周星驰”
灯台树(Alstonia scholaris):东南亚的药用乔木瑰宝
车损险和三者险的区别,车损和三者哪个重要
【反邪教知识科普】抵制邪教 从我做起
吃柿子有哪些禁忌
中华盗龙有多大?中华盗龙生活在哪个时期?
孕妇接种新冠疫苗安全吗?对母体和胎儿的影响【医师监修】
揭秘日本“天皇”称号的由来及其与中国的关系
浅析经济学中的统计学论文
聚苯醚(PPO)市场规模不断增长 我国改性聚苯醚产能有望扩张
日元跌至30年新低,赴日旅游真的能省钱吗?
地球生命起源探索的突破与疑问
美团、饿了么上线防疲劳机制,骑手过度跑单会被强制下线
重庆大轰炸幸存者缅怀遇难同胞:历史伤痛一刻未忘
近7亿元一艘造了72艘!中国056型护卫舰,为何会沦为鸡肋?
项目部混凝土管理全攻略:从材料到养护的系统指南
内蒙古鄂尔多斯市东胜区:让每个孩子沐浴教育均衡化发展的阳光
探析开封火爆的"流量密码"
手机智能助手:便捷生活背后的隐私安全隐忧
2024新晋秋冬流行色曝光:“米色系”!温柔又显贵,早穿早美
梅花易数分类预测的详细解读(下)
剃须技巧与护理:提升剃须体验的全面指南与建议