最近项目迁移到新集群,试试同事推荐的开源任务调度程序-azkaban,azikaban主要用来解决hadoop依赖任务的执行,但是它本身支持linux和java程序,因此适合做小项目的任务调度管理程序。

它有三个重要组件:

1 关系数据库(目前仅支持mysql)

2 web管理服务器-AzkabanWebServer

3 执行服务器-AzkabanExecutorServer

图1 组件


开始

Azkaban有三种运行模式:

1 solo server mode:最简单的模式,数据库内置的H2数据库,管理服务器和执行服务器都在一个进程中运行,任务量不大项目可以采用此模式。

2 two server mode:数据库为mysql,管理服务器和执行服务器在不同进程,这种模式下,管理服务器和执行服务器互不影响

3 multiple executor mode:该模式下,执行服务器和管理服务器在不同主机上,且执行服务器可以有多个。

我们项目要求不是太高,我这次采用第二种模式,管理服务器、执行服务器分进程,但在同一台主机上。

安装

azkaban和官方说的一样,简单易用,先到官网下载相关包并解压,我下载的是:

azkaban-executor-server-2.5.0.tar.gz(执行服务器)
azkaban-web-server-2.5.0.tar.gz(管理服务器)
azkaban-sql-script-2.5.0.tar.gz(mysql脚本)

数据库安装配置

数据库创建

#不一定非要命名为'azkaban'
mysql>CREATE DATABASE azkaban;#创建用户和密码
mysql>CREATE USER 'username'@'%'IDENTIFIED BY 'password';#给用户相关权限
mysql>GRANT SELECT,INSERT,UPDATE,DELETEON <database>.* to '<username>'@'%' WITH GRANT OPTION;

数据库配置

编辑/etc/my.cnf

[mysqld]
max_allowed_packet=1024M

重启服务器

执行脚本

执行下载包azkaban-sql-script-2.5.0.tar.gz中脚本“create-all-sql”

检查下载包web和executor的lib文件下是否有mysql驱动,若不存在,则拷贝一个

web管理服务器(azkaban-web-2.5.0)

有几个重要目录和配置文件

文件夹        解释
bin           用来存放启动和停止脚本
conf<span style="font-family: Arial, Helvetica, sans-serif;">                    </span>配置文件,最重要的配置azkaban.properties
lib           jar文件,查看是否存在mysql驱动
extlib        扩展lib
plugins       扩展插件,有hdfs、hive、pig等
web           web目录

配置conf中azkaban.properties,其他默认即可

#设置项目名称
azkaban.name=BigData
#设置项目副标题
azkaban.label=besttone
#一定要设置为上海,否则按美国时间执行
default.timezone.id=Asia/Shanghaidatabase.type=mysql
mysql.port=3306
mysql.host=localhost
#改为自己的数据库名称
mysql.database=azkaban
#改为自己的数据库账号
mysql.user=azkaban
#改为自己的数据库密码
mysql.password=azkaban_abcmail.sender=email账号
mail.host=email服务器
mail.user=email账号
mail.password=email密码#Azkaban Jetty 服务设置,先安装此配置,后面再详细介绍生产方法.
jetty.maxThreads=25
jetty.ssl.port=8443
jetty.port=8081
jetty.keystore=web/keystore
jetty.password=besttone
jetty.keypassword=besttone
jetty.truststore=web/truststore
jetty.trustpassword=besttone

jetty ssl配置

jetty ssl keystore生成

keytool -genkey -keystore keystore -aliasjetty-azkaban -keyalg RSA -validity 3560

根据提示输入相关信息,我的密码为besttone,和上面的password对应

keytool -export -alias jetty-azkaban-keystore keystore -rfc -file selfsignedcert.cer

过程中如果要输入密码,请输入之前密码

keytool -import -alias certificatekey -fileselfsignedcert.cer -keystore truststore

这时候在web目录下新建key目录,将生成的keystore,truststore拷贝进去

执行启动命令

./bin/azkaban-web-start.sh

也可以执行nohup,后台运行

nohup ./bin/azkaban-web-start.sh &

关闭命令

./bin/azkaban-web-shutdown.sh

访问https://localhost:8443

输入账号和密码,都是azkaban,如果要更改,请修改conf/azkaban-users.xml文件

至此已经可以看到web管理界面了,下面执行需要启动执行服务器。

ps:如果本地可以执行,远程无法执行,看是否远程服务器禁用8443端口,将8443改为8888即可。

3.执行服务器

修改conf/azkaban.properties文件,其他默认

default.timezone.id=Asia/Shanghai
database.type=mysql
mysql.port=3306
mysql.host=localhost
mysql.database=azkaban
mysql.user=azkaban
mysql.password=azkaban_abc

执行脚本,启动执行服务器

./bin/azkaban-executor-start.sh

也可以执行nohup,后台运行

nohup ./bin/azkaban-executor-start.sh &

关闭命令

./bin/azkaban-executor-shutdown.sh

4.安装扩展控件

azkaban有很多插件,hdfs、hive、pig等,如有兴趣自行安装,本次项目未用到

http://www.jianshu.com/p/cc680380ca34

Azkaban——安装指南相关推荐

  1. Storm 0.9安装指南

    Storm 0.9.2安装指南 0 Storm0.9的亮点 引用网上的描写叙述: "Storm 0.9.0.1版本号的第一亮点是引入了netty transport.Storm网络传输机制实 ...

  2. Azkaban入门(启动一个Simple Example)

    Azkaban简介 azkaban是一个开源的任务调度系统 Azkaban是一套简单的任务调度服务,整体包括三部分webserver.dbserver.executorserver. 开发语言为Jav ...

  3. 10个深度学习软件的安装指南(附代码)

    来源:AI前线 本文长度为2385字,建议阅读4分钟 本文为你介绍10个深度学习软件安装指南. 由于近期论文的需要,我搭建了一个基于 Ubuntu 和英伟达的深度学习环境.尽管已经有很多非常棒的关于英 ...

  4. Facebook Docusaurus 中文文档 安装指南

    此系列文章的应用示例已发布于 GitHub: docusaurus-docs-Zh_CN. 可以 Fork 帮助改进或 Star 关注更新. 欢迎 Star. 安装指南 Docusaurus 是从全新 ...

  5. apache hadoop 2.4.0 64bit 在windows8.1下直接安装指南(无需虚拟机和cygwin)

    工作须要.要開始搞hadoop了,又是大数据,自己感觉大数据.云.仅仅是ERP.SOAP风潮之后与智能地球一起诞生的概念炒作. 只是Apache是个奇妙的组织.Java假设没有它也不会如今如火中天.言 ...

  6. VS2005中ajax安装指南[转]

    2019独角兽企业重金招聘Python工程师标准>>> VS2005中ajax安装指南[转] 以下是收集关于AjaxControlToolkit安装的一篇文章,感谢原作者 AjaxC ...

  7. 本机安装PaddlePaddle - 安装指南

    简 介: 根据 文档安装指南 介绍了在本机安装PaddlePaddle的步骤. 关键词: PaddlePaddle,pip,安装 #mermaid-svg-RMWtzcncmslaS8dM {font ...

  8. azkaban 与 java任务_Azkaban的任务类型分析35:JavaProcessJob的执行

    我们知道,在azkaban内部有好几种调度程序,那么一个java程序怎么被执行的呢? ========================================================= ...

  9. [WTL] STLport安装指南

    STLport安装指南 STLport-4.6 是完全兼容ANSI C++标准的类库. This distribution contains STLport sources only, no bina ...

最新文章

  1. html生成缩略图来预览解决方案
  2. 虚拟内存——Windows核心编程学习手札之十四
  3. 【C++教程】02.环境配置
  4. 由作用域安全的构造函数想到的
  5. createprocess失败代码2_pytest文档57单元测试代码覆盖率(pytestcov)
  6. 4-2 ADO.NET-查询和检索数据13
  7. SAP License:FI中的表连接与应用
  8. css清除浮动的几种方法_清除浮动的几种方法
  9. [编写高质量代码:改善java程序的151个建议]建议43 避免对象浅拷贝; 建议44:推荐使用序列化实现对象的深拷贝...
  10. 小D课堂 - 新版本微服务springcloud+Docker教程_5-03 feign结合hystrix断路器开发实战上...
  11. java笔试题大全_java笔试题大全带答案(经典11题)
  12. aria2Android服务器教程,Aria2自动更新BT Tracker服务器列表的方法
  13. Domain Adaptation理论分析
  14. 电机速度rpm转换成轮子的速度
  15. html打印页标题行,打印标题行的设置方法
  16. 十、什么是临界资源及如何访问临界资源
  17. matlab中imresize函数
  18. 【OS学习笔记】二十五 保护模式七:任务和特权级保护对应的汇编源代码
  19. Java SE MyBatis框架(详解)
  20. VVIC api接口

热门文章

  1. 关于EAD: Elastic-Net Attacks to Deep Neural Networks via Adversarial Examples的理解
  2. Linux之tail查看命令
  3. 全面解读Group Normbalization-(吴育昕-何凯明)
  4. Java后台框架篇--Spring之WebFlow
  5. three.js之光源
  6. 手机放法分析,放哪里最好?辐射小?
  7. matlab fsk 解调算法,FSK信号频谱分析附解调实现.doc
  8. 爬虫(成都58同城所有房价,Python实现)
  9. jsplumb分组拖拽
  10. neovim及coc.nvim自动补全初探