助力工业物联网,工业大数据之服务域:AirFlow的介绍【三十一】

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 助力工业物联网,工业大数据之服务域:AirFlow的介绍【三十一】

02:任务流调度回顾

  • 目标回顾任务流调度的需求及常用工具
  • 路径
  • step1:需求
  • step2:常用工具
  • 实施
  • 需求
  • 相同的业务线,有不同的需求会有多个程序来实现,这多个程序共同完成的需求,组合在一起就是工作流或者叫做任务流
  • 基于工作流来实现任务流的自动化运行

  • 需求1:基于时间的任务运行
  • job1和job2是每天0点以后自动运行
  • job3必须等待job1运行成功才能运行
  • job5必须等待job3和job4都运行成功才能运行
  • 调度类型
  • 定时调度:基于某种时间的规律进行调度运行
  • 调度工作流
  • 依赖调度:基于某种依赖关系进行调度运行
  • 工作流中的程序的依赖关系
  • 常用工具
  • Oozie:Cloudera公司研发,功能强大,依赖于MR实现分布式,集成Hue开发使用非常方便
  • 传统开发:xml文件
<workflow>
  <start to="action1">
  </start>
  <action name='action1'>
    <shell>
    </shell>
    <ok to='action2'>
    <kill to='killAction'>
  </action>
  <action name='action2'>
    <shell>
    </shell>
    <ok to='action3'>
    <kill to='killAction'>
  </action>
  ……
</workflow>
  • 现在开发:Hue通过图形化界面自主编辑DAG
  • 场景:CDH大数据平台
  • Azkaban:LinkedIn公司研发,界面友好、插件支持丰富、自主分布式,可以使用properties或者JSON开发
  • 开发properties文件,压缩成zip压缩包
name='appname2'
type=command
dependencies=appname1
comman='sh xxxx.sh'
  • 上传到web界面中
  • 场景:Apache平台
  • AirFlow:Airbnb公司研发,自主分布式、Python语言开发和交互,应用场景更加丰富
  • 开发Python文件
# step1:导包
# step2:函数调用
  • 提交运行
  • 场景:整个数据平台全部基于Python开发
  • DolphinScheduler:易观公司研发,国产开源产品,高可靠高扩展、简单易用
  • 小结
  • 回顾任务流调度的需求及常用工具

03:AirFlow的介绍

  • 目标了解AirFlow的功能特点及应用场景
  • 路径
  • step1:背景
  • step2:设计
  • step3:功能
  • step4:特点
  • step5:应用
  • 实施
  • 起源
  • 2014年,Airbnb创造了一套工作流调度系统:Airflow,用来替他们完成业务中复杂的ETL处理。从清洗,到拼接,只用设置好一套Airflow的流程图。
  • 2016年开源到了Apache基金会。
  • 2019年成为了Apache基金会的顶级项目:http://airflow.apache.org/
  • 设计:利用Python的可移植性和通用性,快速的构建的任务流调度平台
  • 功能:基于Python实现依赖调度、定时调度
  • 特点
  • 分布式任务调度:允许一个工作流的Task在多台worker上同时执行
  • DAG任务依赖:以有向无环图的方式构建任务依赖关系
  • Task原子性:工作流上每个task都是原子可重试的,一个工作流某个环节的task失败可自动或手动进行重试
  • 自主定制性:可以基于代码构造任何你需要调度的任务或者处理工具
  • 优点:灵活性好
  • 缺点:开发复杂
  • 应用
  • 基于Python开发背景下的系统建议使用
  • 小结
  • 了解AirFlow的功能特点及应用场景

04:AirFlow的部署启动

  • 目标了解AirFlow的工具部署及管理
  • 路径
  • step1:安装部署
  • step2:启动测试
  • step3:关闭
  • 实施
  • 安装部署
  • 自行安装:《参考附录一》
  • 放弃安装:请将虚拟机快照恢复到《AirFlow安装完成》
  • 启动测试
  • 删除记录:第二次启动再做
rm -f /root/airflow/airflow-*
  • 启动Redis:消息队列:
  • nohub非挂起redis任务,/opt/redis-4.0.9/src/redis-server
  • 加载redis配置文件,/opt/redis-4.0.9/src/redis.conf
  • output.log为存储日志文件
  • 2>&1中2代表错误日志,重定向为正确日志记录再output.log中,否则错误日志会在linux命令行打印
  • &后台
nohup /opt/redis-4.0.9/src/redis-server /opt/redis-4.0.9/src/redis.conf > output.log 2>&1 &
ps -ef | grep redis
  • 启动AirFlow
# 以后台进程方式,启动服务
airflow webserver -D
airflow scheduler -D
airflow celery flower -D
airflow celery worker -D
  • 测试网络端口
  • Airflow Web UI:node1:8085
  • 用户名密码:admin
  • Celery Web UI:node1:5555
  • 小结
  • 了解AirFlow的工具部署及管理


相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
目录
相关文章
|
2月前
|
存储 数据可视化 数据管理
基于阿里云服务的数据平台架构实践
本文主要介绍基于阿里云大数据组件服务,对企业进行大数据平台建设的架构实践。
721 2
|
4月前
|
SQL 存储 大数据
某互联网大厂亿级大数据服务平台的建设和实践
某互联网大厂亿级大数据服务平台的建设和实践
68 0
|
26天前
|
分布式计算 运维 数据挖掘
MaxCompute是一个强大的云数据仓库服务
【4月更文挑战第1天】MaxCompute是一个强大的云数据仓库服务
25 1
|
2月前
|
监控 物联网 大数据
智慧工地管理平台系统源码基于物联网、云计算、大数据等技术
智慧工地平台APP通过对施工过程人机料法环的全面感知、互联互通、智能协同,提高施工现场的生产效率、管理水平和决策能力,实现施工管理的数字化、智能化、精益化。
56 0
|
3月前
|
数据可视化 大数据 数据挖掘
瓴羊荣获2023虎啸奖“年度十大AI&大数据服务公司”“数智营销案例铜奖”双重大奖
瓴羊荣获2023虎啸奖“年度十大AI&大数据服务公司”“数智营销案例铜奖”双重大奖
|
4月前
|
SQL 存储 大数据
从0到1介绍一下开源大数据服务平台dataService
从0到1介绍一下开源大数据服务平台dataService
116 1
|
4月前
|
NoSQL 物联网 大数据
【补充】助力工业物联网,工业大数据之AirFlow安装
【补充】助力工业物联网,工业大数据之AirFlow安装
59 1
|
4月前
|
Prometheus 数据可视化 Cloud Native
助力工业物联网,工业大数据之服务域:可视化工具Grafana介绍【三十八】
助力工业物联网,工业大数据之服务域:可视化工具Grafana介绍【三十八】
104 1
|
2月前
|
分布式计算 DataWorks IDE
MaxCompute数据问题之忽略脏数据如何解决
MaxCompute数据包含存储在MaxCompute服务中的表、分区以及其他数据结构;本合集将提供MaxCompute数据的管理和优化指南,以及数据操作中的常见问题和解决策略。
47 0
|
2月前
|
SQL 存储 分布式计算
MaxCompute问题之下载数据如何解决
MaxCompute数据包含存储在MaxCompute服务中的表、分区以及其他数据结构;本合集将提供MaxCompute数据的管理和优化指南,以及数据操作中的常见问题和解决策略。
38 0

热门文章

最新文章