azkaban安装与使用

2024-02-16 12:18
文章标签 安装 使用 azkaban

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

1.      下载azkaban3.25的”source code.tar.gz”: https://github.com/azkaban/azkaban/releases

2.      解压缩:azkaban-3.25.0.tar.gz,进入azkaban根目录:cd azkaban-3.25.0

3.      执行命令:./gradlew installDist  生成相关文件

4.      创建一个新的文件夹:mkdir azkaban ,复制以下文件内容到XXX目录下:

cp /azkaban-3.25.0/azkaban-web-server/build/install/azkaban-web-server  azkaban

cp /azkaban-3.25.0/azkaban-exec-server/build/install/azkaban-exec-server azkaban

cp /azkaban-3.25.0/azkaban-db/build/install/azkaban-web-server azkaban

5.      在mysql数据库中创建一个数据库:azkaban 

进入azkaban数据库:use Azkaban 

执行:source /azkaban-3.25.0/azkaban-db/create-all-sql-0.1.0-SNAPSHOT.sql

6.      创建SSL配置:keytool -keystore keystore -alias jetty -genkey -keyalg RSA

提示中只需填写个6位密码即可,其他信息可填可不填

将生成的keystore文件拷贝至XXX目录下:cpkeystore /XXX/azkaban-web-server

7.      先配置好服务器节点上的时区

先生成时区配置文件Asia/Shanghai,用交互式命令 tzselect 即可

拷贝该时区文件,覆盖系统本地时区配置

cp/usr/share/zoneinfo/Asia/Shanghai /etc/localtime

8.      配置azkaban-web-server的conf下的文件:

配置Azkaban.properties

#AzkabanPersonalization Settings

azkaban.name=Test

azkaban.label=MyLocal Azkaban

azkaban.color=#FF3601

azkaban.default.servlet.path=/index

web.resource.dir=web/

default.timezone.id=Asia/Shanghai

 

#AzkabanUserManager class

user.manager.class=azkaban.user.XmlUserManager

user.manager.xml.file=conf/azkaban-users.xml

 

#Loaderfor projects

executor.global.properties=conf/global.properties

azkaban.project.dir=projects

 

database.type=mysql

mysql.port=3306

mysql.host=localhost

mysql.database=azkaban

mysql.user=root

mysql.password=1234

mysql.numconnections=100

 

#Velocity dev mode

velocity.dev.mode=false

 

# AzkabanJetty server properties.

jetty.maxThreads=25

jetty.ssl.port=8443

jetty.port=8081

jetty.keystore=keystore

jetty.password=123456

jetty.keypassword=123456

jetty.truststore=keystore

jetty.trustpassword=123456

 

# AzkabanExecutor settings

executor.port=12321

 

# mailsettings

mail.sender=

mail.host=

job.failure.email=

job.success.email=

 

lockdown.create.projects=false

 

cache.directory=cache

 

配置azkaban-users.xml

<azkaban-users>

<user username="azkaban"password="azkaban" roles="admin" groups="azkaban"/>

<user username="metrics"password="metrics" roles="metrics"/>

<user username="admin"password="admin" roles="admin,metrics" />

<role name="admin"permissions="ADMIN" />

<role name="metrics"permissions="METRICS"/>

</azkaban-users>

 

配置log4j.properties

log4j.rootLogger=INFO,C

log4j.appender.C=org.apache.log4j.ConsoleAppender

log4j.appender.C.Target=System.err

log4j.appender.C.layout=org.apache.log4j.PatternLayout

log4j.appender.C.layout.ConversionPattern=%d{yyyy-MM-ddHH:mm:ss} %-5p %c{1}:%L - %m%n

 

 

 

9.      配置azkaban-exec-server的conf下的文件

配置azkaban.properties

#Azkaban

default.timezone.id=Asia/Shanghai

 

# AzkabanJobTypes Plugins

azkaban.jobtype.plugin.dir=plugins/jobtypes

 

#Loaderfor projects

executor.global.properties=conf/global.properties

azkaban.project.dir=projects

 

azkaban.native.lib=

 

database.type=mysql

mysql.port=3306

mysql.host=localhost

mysql.database=azkaban

mysql.user=root

mysql.password=1234

mysql.numconnections=100

 

# AzkabanExecutor settings

executor.maxThreads=50

executor.port=12321

executor.flow.threads=30

 

# JMXstats

jetty.connector.stats=true

executor.connector.stats=true

 

log4j.properties

log4j.rootLogger=INFO,C

log4j.appender.C=org.apache.log4j.ConsoleAppender

log4j.appender.C.Target=System.err

log4j.appender.C.layout=org.apache.log4j.PatternLayout

log4j.appender.C.layout.ConversionPattern=%d{yyyy-MM-ddHH:mm:ss} %-5p %c{1}:%L - %m%n

 

配置/plugins/jobtypes/commonprivate.proterties

# setexecute-as-user

execute.as.user=false


#关闭内存检查,若可用内存空间小于3GB会报错

memCheck.enabled=false

 

10.  测试

新建一个任务:command.job

vi command.job

#command.job

type=command

command=echo 'hello azkaban'

 

将command.job打包成zip文件:zipcommand.job

在浏览器中输入url:https://localhost:8443,输入配置好的用户和密码,进入azkaban web client


点击[Create Project],输入项目名和描述

上传command.job.zip


执行流


 

 注:过程中可能遇到的错误:

①若azkaban-web-server和azkaban-exec-server的目录conf无log4j.properties文件则会报以下错误:

Exception: java.lang.StackOverflowError thrown from the UncaughtExceptionHandler in thread "main"

②若/azkaban-exec-server/plugins/jobtypes/下commonprivate.proterties文件未配置,则会报以下错误:

未配置:execute.as.user=false 

azkaban.utils.UndefinedPropertyException:Missing required property 'azkaban.native.lib'

atazkaban.utils.Props.getString(Props.java:478)

atazkaban.jobExecutor.ProcessJob.run(ProcessJob.java:155)

at azkaban.execapp.JobRunner.runJob(JobRunner.java:694)

atazkaban.execapp.JobRunner.run(JobRunner.java:544)

atjava.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)

atjava.util.concurrent.FutureTask.run(FutureTask.java:266)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)

atjava.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)

at java.lang.Thread.run(Thread.java:745)

22-06-2017 09:53:16 CST a ERROR - Missing required property'azkaban.native.lib' cause: null

 未配置:memCheck.enabled=false

java.lang.Exception: Cannot request memory (Xms 0 kb, Xmx 0 kb) from system for job a  

    at azkaban.jobExecutor.ProcessJob.run(ProcessJob.java:86)  

    at azkaban.execapp.JobRunner.runJob(JobRunner.java:590)  

    at azkaban.execapp.JobRunner.run(JobRunner.java:443)  

    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)  

    at java.util.concurrent.FutureTask.run(FutureTask.java:266)  

    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)      

    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)      

    at java.lang.Thread.run(Thread.java:745) 

 

 

 

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



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

相关文章

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

使用Python实现一个简易计算器的新手指南

《使用Python实现一个简易计算器的新手指南》计算器是编程入门的经典项目,它涵盖了变量、输入输出、条件判断等核心编程概念,通过这个小项目,可以快速掌握Python的基础语法,并为后续更复杂的项目打下... 目录准备工作基础概念解析分步实现计算器第一步:获取用户输入第二步:实现基本运算第三步:显示计算结果进

python之uv使用详解

《python之uv使用详解》文章介绍uv在Ubuntu上用于Python项目管理,涵盖安装、初始化、依赖管理、运行调试及Docker应用,强调CI中使用--locked确保依赖一致性... 目录安装与更新standalonepip 安装创建php以及初始化项目依赖管理uv run直接在命令行运行pytho

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Kotlin 枚举类使用举例

《Kotlin枚举类使用举例》枚举类(EnumClasses)是Kotlin中用于定义固定集合值的特殊类,它表示一组命名的常量,每个枚举常量都是该类的单例实例,接下来通过本文给大家介绍Kotl... 目录一、编程枚举类核心概念二、基础语法与特性1. 基本定义2. 带参数的枚举3. 实现接口4. 内置属性三、

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看