Azkaban官网文档1-概述-Overvie

2023-10-23 11:50

本文主要是介绍Azkaban官网文档1-概述-Overvie,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Azkaban是在LinkedIn上实现的,用来解决Hadoop作业依赖的问题。我们的工作需要按顺序运行,从ETL工作到数据分析产品。

Azkaban最初是一个单一的服务器解决方案,随着多年来Hadoop用户数量的增加,它已经发展成为一个更健壮的解决方案。

Azkaban由三个关键部分组成:

  1. 关系型数据库(MySQL)
  2. AzkabanWebServer
  3. AzkabanExecutorServer

Relational Database (MySQL)

Azkaban使用MySQL来存储它的大部分状态。AzkabanWebServer和AzkabanExecutorServer都访问数据库。

AzkabanWebServer 是如何访问数据库的?

web服务器使用数据库的原因如下:

  1. 项目管理——项目、项目权限、上传文件。
  2. 执行工作流状态——跟踪执行工作流以及哪个执行器正在运行它们。
  3. 以前的工作流/作业——搜索以前执行的作业和工作流,并访问它们的日志文件。
  4. 调度程序——保持调度作业的状态。
  5. SLA——保持所有SLA规则

AzkabanExecutorServer 用数据库来干啥?

  1. 访问项目——从数据库中检索项目文件。
  2. 执行工作流/作业——检索和更新正在执行的工作流的数据
  3. 日志——将作业和工作流的输出日志存储到数据库中。
  4. 互流依赖——如果一个工作流在不同的执行程序上运行,它将从数据库获取状态。

选择MySQL的原因是它是一个广泛使用的数据库。我们希望实现与其他数据库的兼容性,尽管在历史上运行作业的搜索需求受益于关系数据存储。

 

AzkabanWebServer

AzkabanWebServer是阿兹卡班的主要管理器。它处理项目管理、身份验证、调度器和执行监视。它还充当web用户界面。

使用Azkaban很容易,Azkaban使用*.job键值属性文件定义工作流中的各个任务,_dependencies_属性定义作业的依赖链。这些作业文件和相关代码可以归档到一个*.zip文件中,并通过Azkaban UI或curl通过web服务器上传。

AzkabanExecutorServer

以前的Azkaban版本同时具有AzkabanWebServer和AzkabanExecutorServer的功能。后来,执行程序被分离到它自己的服务器中。拆分这些服务有几个原因:我们很快就可以扩展执行的数量,如果有一个失败,我们就可以使用操作执行器。同时,我们能够在对用户影响最小的情况下升级Azkaban。随着Azkaban的使用增加,我们发现升级Azkaban变得越来越困难,因为一天中的任何时候都变成了“高峰”。

Getting Started

在3.0版本中,我们提供了三种模式:独立的“单服务器”模式、较重的双服务器模式和分布式多执行器模式。下面将介绍这两种模式之间的区别。

在solo服务器模式下,DB嵌入H2, web服务器和executor服务器在同一个进程中运行。如果你只是想尝试一下,这应该是有用的。它也可以在小规模的用例中使用。

Download and Install Solo Server Package

Install Azkaban Plugins

两种服务器模式适用于更复杂的生产环境。它的DB应该由主-从设置的MySQL实例来支持。web服务器和executor服务器应该运行在不同的进程中,因此升级和维护不应该影响用户。

  1. Set up the database
  2. Download and install the Web Server
  3. Download and install the Executor Server
  4. Install Azkaban Plugins

多执行器模式适用于最正式的生产环境。它的DB应该由主-从设置的MySQL实例来支持。理想情况下,web服务器和执行服务器应该运行在不同的主机上,这样升级和维护就不会影响用户。这种多主机设置为azkaban带来了健壮和可伸缩的方面。

  1. Set up the database
  2. Download and install the Web Server
  3. Configure database to use multiple executors
  4. Download and install the Executor Server for each executor configured in database
  5. Install Azkaban Plugins

下面是如何设置azkaban的说明。

Azkaban构建使用Gradle(使用gradlew (Gradle包装器)自动下载),需要Java 8或更高版本。

下面的命令运行在*nix平台上,比如Linux, OS X。

 # Build Azkaban./gradlew build# Clean the build./gradlew clean# Build and install distributions./gradlew installDist# Run tests./gradlew test# Build without running tests./gradlew build -x test

这些都是标准的gradle指令。请查看Gradle文档获取更多信息。

Gradle在项目目录中创建.tar.gz文件。如。

./azkaban-solo-server/build/distributions/azkaban-solo-server-0.1.0-SNAPSHOT.tar.gz. 
Untar using 
tar -xvzf path/to/azkaban-*.tar.gz.

Getting started with the Solo Server

solo Server是azkaban的一个独立实例,也是最简单的入门工具。solo服务器有以下优点。

  1. 易于安装-不需要MySQL实例。它将H2打包为主要的持久性存储。
  2. 易于启动——web服务器和executor服务器运行在同一个进程中。
  3. 全功能-它包所有阿兹卡班功能。你可以用正常的方式使用它,并为它安装插件。

安装方法:

  1. Clone the repo: run git clone https://github.com/azkaban/azkaban.git
  2. Build Azkaban and create an installation: run cd azkaban; ./gradlew build installDist
  3. Start the server: run cd azkaban-solo-server/build/install/azkaban-solo-server; bin/azkaban-solo-start.sh
  4. Stop server: run bin/azkaban-solo-shutdown.sh from within the azkaban-solo-server installation directory

solo-server安装应该包含以下目录。

FolderDescription
binThe scripts to start/stop Azkaban jetty server
confThe configuration files for Azkaban solo server
libThe jar dependencies for Azkaban
extlibAdditional jars that are added to extlib will be added to Azkaban's classpath
pluginsthe directory where plugins can be installed
webThe web (css, javascript, image) files for Azkaban web server.

在conf目录中,应该有三个文件:

azkaban.private.properties - 运行时参数
azkaban.properties - 使用运行时参数
global.properties - 作为共享属性传递给每个工作流和作业的全局静态属性。
azkaban-users.xml - 用于为身份验证添加用户和角色。如果XmLUserManager没有设置为使用该文件,则不使用该文件。

azkaban.properties是最主要的配置文件

Getting KeyStore for SSL (Optional)

阿兹卡班solo服务器默认不使用SSL。但是您可以在独立的web服务器上以相同的方式进行设置。这里是:

Azkaban web服务器可以使用SSL套接字连接器,这意味着密钥库必须是可用的。您可以按照这个链接提供的步骤进行调用([http://docs.codehaus.org/display/JETTY/How+to+configure+SSL](http://docs.codehaus.org/display/JETTY/How+to+configure+SSL)) 创建一个。创建密钥存储库文件后,必须向azkaban提供其位置和密码。azkaban.properties,应重写下列属性。

jetty.keystore=keystore
jetty.password=password
jetty.keypassword=password
jetty.truststore=keystore
jetty.trustpassword=password

下面就不写了,大家自己看吧:

https://azkaban.readthedocs.io/en/latest/index.html#

 

这篇关于Azkaban官网文档1-概述-Overvie的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

Python实现自动化删除Word文档超链接的实用技巧

《Python实现自动化删除Word文档超链接的实用技巧》在日常工作中,我们经常需要处理各种Word文档,本文将深入探讨如何利用Python,特别是借助一个功能强大的库,高效移除Word文档中的超链接... 目录为什么需要移除Word文档超链接准备工作:环境搭建与库安装核心实现:使用python移除超链接的

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法