Azkaban安装与初步使用

2024-01-13 06:08
文章标签 安装 使用 初步 azkaban

本文主要是介绍Azkaban安装与初步使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Azkaban安装与使用

  • 1 引言
    • 1.1 目的
    • 1.2 背景
    • 1.3 术语
    • 1.4 参考资料
    • 1.5 读者对象
  • 2 运行环境
    • 2.1 软件方面
  • 3 系统环境安装
  • 4 软件安装和配置
    • 4.1 下载代码,构建资源
    • 4.2 启动和停止服务
    • 4.3 通过web打开Azkaban可视化界面
    • 4.4 功能验证
  • 5 常见问题处理
    • 5.1 构建时报错

1 引言

1.1 目的

  1. 通过Azkaban的批量工作量任务调度器调用kettle
  2. 调用linux命令
  3. 调用java程序
  4. 调用shell脚本

1.2 背景

    Azkaban是一个分布式工作流管理器,由LinkedIn实现。类似于JavaEE中的JBPM和Activiti工作流框架.。常见的任务调度框架有Apache Oozie、LinkedIn Azkaban、Apache Airflow、Alibaba Zeus,由于Azkaban具有轻量可插拔、友好的WebUI、SLA告警、完善的权限控制、易于二次开发等优点,也得到了广泛应用。

1.3 术语

表格 1 3:术语表

术语说明
FLOW工作流程
JOB作业

1.4 参考资料

Azkaban官网网站:https://azkaban.github.io/

1.5 读者对象

    开发人员、运维人员、大数据工程师

2 运行环境

2.1 软件方面

这里我以我自己本地的环境作为例子,仅供参考

序号软件名称版本
1VMware Workstation 15 Pro15.0.0
2Azkaban3.9.1.0
3Gradle6.6.1
4JDK1.8.0_261
5Git2.17.1

3 系统环境安装

Ubuntu 18.04.5 LTS

4 软件安装和配置

4.1 下载代码,构建资源

  1. 克隆仓库
    git clone https://github.com/azkaban/azkaban.git
  2. 构建项目
    sudo ./gradlew build -x test
  3. 清理项目
    sudo ./gradlew clean

4.2 启动和停止服务

进入Azkaban根目录后
cd /azkaban/azkaban-solo-server/build/install/azkaban-solo-server/
执行 sudo ./bin/start-solo.sh 启动solo-server服务
执行 sudo./bin/shutdown-solo.sh,停止solo-server服务

4.3 通过web打开Azkaban可视化界面

  在浏览器中输入http://localhost:8081/,由于我将Azkaban安装在了虚拟机上,所以此处我使用的是http://192.168.255.131:8081/,默认的账号名为azkaban,密码为azkaban。
登录页
在这里插入图片描述

4.4 功能验证

1. 创建一个名为flow20.project的文件。添加Azkaban版本,表明这是一个Azkaban 2.0项目
azkaban-flow-version: 2.0
2. 创建另一个名为basic.flow的文件。添加名为nodes的部分,其中将包含您想要运行的所有作业。
nodes:

  • name: jobC
    type: noop
    # jobC depends on jobA and jobB
    dependsOn:

    • jobA
    • jobB
  • name: jobA
    type: command
    config:
    command: echo “This is an echoed text.”

  • name: jobB
    type: command
    config:
    command: pwd
    3. 将两个文件压缩为zip文件,直接压缩即可,不需要在外层创建文件夹,并命名为Archive.zip
    4. 在project菜单下创建一个project,输入Name和Description,如official_demo和官方样例
    5. 创建完毕后,点击upload菜单,将第三步压缩的Archive.zip进行上传
    在这里插入图片描述
    6. 点击Execute Flow,会弹出调度视图,再次点击Execute即运行成功
    在这里插入图片描述
    7. 查看调度日志
    在这里插入图片描述

5 常见问题处理

5.1 构建时报错

Task :azkaban-exec-server:compileTestJava FAILED
/home/caijx/download/azkaban/azkaban-exec-server/src/test/java/azkaban/dag/StatusChangeRecorder.java:24: 错误: 程序包javafx.util不存在
import javafx.util.Pair;
^
/home/caijx/download/azkaban/azkaban-exec-server/src/test/java/azkaban/dag/StatusChangeRecorder.java:31: 错误: 找不到符号
private final List<Pair<String, Status>> sequence = new ArrayList<>();
^
符号: 类 Pair
位置: 类 StatusChangeRecorder
/home/caijx/download/azkaban/azkaban-exec-server/src/test/java/azkaban/dag/StatusChangeRecorder.java:41: 错误: 找不到符号
void verifySequence(final List<Pair<String, Status>> expectedSequence) {
^
符号: 类 Pair
位置: 类 StatusChangeRecorder
/home/caijx/download/azkaban/azkaban-exec-server/src/test/java/azkaban/dag/DagServiceTest.java:32: 错误: 程序包javafx.util不存在
import javafx.util.Pair;
^
/home/caijx/download/azkaban/azkaban-exec-server/src/test/java/azkaban/dag/DagServiceTest.java:56: 错误: 找不到符号
private final List<Pair<String, Status>> expectedSequence = new ArrayList<>();
^
解决办法:构建时使用sudo ./gradlew build -x test,最根本的原因为我所使用的环境安装的为OpenJDK,只包含最精简的JDK,故我又重新安装了JDK 1.8.0_261。安装完毕后使用sudo ./gradlew build依旧构建不通过。百思不得其解, 但不执行测试代码可以通过。有兴趣的小伙伴可以自行研究下。

这篇关于Azkaban安装与初步使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/600477

相关文章

pandas DataFrame keys的使用小结

《pandasDataFramekeys的使用小结》pandas.DataFrame.keys()方法返回DataFrame的列名,类似于字典的键,本文主要介绍了pandasDataFrameke... 目录Pandas2.2 DataFrameIndexing, iterationpandas.DataF

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

浅析如何使用xstream实现javaBean与xml互转

《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚