1. 创建项目



    进入Azkaban后,您将看到“项目”页面。此页面将显示您具有读取权限的所有项目的列表。只有组权限或具有READ或ADMIN角色的项目不会出现。



    如果刚刚开始,项目页面可能为空。但是,您可以通过单击所有项目来查看所有现有项目。



单击创建项目将弹出一个对话框。输入项目的唯一项目名称和说明,项目名称必须以英文字母开头,只能包含数字、英文字母、下划线、横线 。以后可以更改说明,但项目名称不能。如果您没有看到此按钮,除了具有适当权限的用户之外,创建新项目的可能性已被锁定。




阿兹卡班调度python 阿兹卡班界面_上传


 


    创建项目后,将显示一个空的项目页面。您将自动获得该项目的ADMIN状态。通过单击权限按钮添加和删除权限。


阿兹卡班调度python 阿兹卡班界面_上传_02


    如果您具有适当的权限(如果您创建项目,则应该该权限),您可以从该页面删除项目,更新描述,上传文件和查看项目日志


2.上传项目


    点击上传按钮。您将看到以下对话框。


阿兹卡班调度python 阿兹卡班界面_阿兹卡班调度python_03


    选择要上传的工作流文件的存档文件。目前,Azkaban只支持xxx.zip文件。zip应包含xxx.job运行作业所需的文件和任何文件。作业名称在项目中必须是唯一的。


    Azkaban将验证zip的内容,以确保满足依赖关系,并且没有检测到循环依赖。如果发现任何无效的工作流,上传将失败。


    上传覆盖项目中的所有文件。在上传新的zip文件后,对作业所做的任何更改都将被清除。


3.工作流视图


    通过点击流程链接,您可以转到流程视图页面。从这里,您将看到流程的图形表示。左侧面板包含流程中的作业列表。


    右键单击右侧面板中的作业或图形中的节点将允许您打开单个作业。您还可以从此页面计划和执行流程。


阿兹卡班调度python 阿兹卡班界面_创建项目_04


 


 


4.项目权限


    创建项目时,创建者将自动在项目上给予ADMIN状态。这允许创建者查看,上传,更改作业,运行流程,删除并向项目添加用户权限。管理员可以删除其他管理员,但不能删除自己。除非管理员被管理角色的用户删除,否则这会阻止项目成为管理员。


    权限页面可从项目页面访问。在权限页面上,管理员可以将其他用户,组或代理用户添加到项目中。


阿兹卡班调度python 阿兹卡班界面_阿兹卡班调度python_05


    添加用户权限为这些用户赋予项目所指定的权限。通过取消选中所有权限来删除用户权限


    组权限允许特定组中的每个人指定的权限。通过取消选中所有组权限来删除组权限。


    如果代理用户已打开,则代理用户允许项目工作流作为这些用户运行。这有助于锁定哪些无头帐户作业可以代理。添加后,点击“删除”按钮即可将其删除。


    每个用户都通过UserManager进行验证,以防止添加无效用户。组和代理用户也将检查以确保它们是有效的,并查看是否允许管理员将其添加到项目中。


可以为用户和组设置以下权限:


Permissions

Values

ADMIN

最高权限,包括给其他用户添加、修改权限

READ

只能访问每一个project的内容和日志信息

WRITE

可以在已创建的project上传、修改任务的属性,可以删除任何的project

EXECUTE

允许用户执行任何的工作流

SCHEDULE

允许用户添加、删除任何工作流的调度信息

CREATEPROJECTS

如果项目创建被锁定,则允许用户创建新项目

 

 


5.执行流程视图


    从流程视图面板中,您可以右键单击图形并禁用或启用作业。在执行期间将禁用残留作业,就像它们的依赖关系一样。残障作业将显示半透明。 


阿兹卡班调度python 阿兹卡班界面_上传_06


通知选项 通知选项允许用户更改流程的成功或失败通知行为。


通知失败


    第一个故障 - 检测到第一个故障后发送故障电子邮件。


    流程完成 - 如果流程的作业失败,它将在流程中的所有作业完成后发送故障电子邮件。


电子邮件覆盖

    Azkaban将使用流中最终作业中设置的默认通知电子邮件。如果被覆盖,用户可以更改发送失败或成功发送电子邮件的电子邮件地址。列表可以用逗号,空格或分号分隔。 


阿兹卡班调度python 阿兹卡班界面_创建项目_07


故障选项


    当流程中的作业失败时,您可以控制其余的流程如何成功。


    完成当前运行将完成当前运行的作业,但不会启动新作业。FAILED FINISHING一旦完成,流程将被置于状态并设置为失败。


    取消全部将立即终止所有正在运行的作业,并将执行流程的状态设置为FAILED。


    完成所有可能会在流程中继续执行作业,只要其依赖性得到满足即可。FAILED FINISHING一旦完成,流程将被置于状态并设置为失败。


阿兹卡班调度python 阿兹卡班界面_创建项目_08


并发选项


    如果流同时执行时调用流执行,则可以设置多个选项。


         如果“ 执行”选项已经运行,则不会运行该流。 运行并发选项将运行流程,无论它是否运行。执行不同的工作目录。


     管道以新执行方式不会超过并发执行的方式运行流程。


        级别1:执行作业A的块,直到上一个流程的作业A完成。


        级别2:执行作业A的块,直到上一个流程的作业A的孩子已经完成。如果您需要在已执行流程后面运行流程,这将非常有用。


阿兹卡班调度python 阿兹卡班界面_创建项目_09


工作流选项


    允许用户覆盖工作流参数。工作流参数覆盖作业的全局属性,而不是作业本身的属性


阿兹卡班调度python 阿兹卡班界面_上传_10


6.执行


    后执行流程,你将提交执行流程页面。或者,您可以从“ 流程视图”页面的“执行”选项卡,“历史记录”页面或“执行”页面访问这些流程。


    此页面类似于“流程视图”页面,但显示运行作业的状态。


阿兹卡班调度python 阿兹卡班界面_上传_11


    选择工作列表将给出执行工作的时间表。您可以直接从此列表中访问作业和作业日志。


阿兹卡班调度python 阿兹卡班界面_上传_12


只要执行没有完成,该页面将自动更新。


您可以在执行流程上执行的一些选项包括:


    取消 - 杀死所有正在运行的作业,并立即失败。流动状态将被杀死。


    暂停 - 阻止新作业运行。目前运行的作业照常进行。

    恢复 - 恢复暂停执行。


    重试失败 - 仅当流程处于FAILED FINISHING状态时可用。当流程仍然活动时,重试将重新启动所有FAILED作业。“尝试”将显示在“作业列表”页面中。


    准备执行 - 仅在完成的流程中可用,无论成功或失败。这将自动禁用成功完成的作业。


7.执行页面


    单击标题中的“执行”选项卡将显示“执行”页面。此页面将显示当前运行的执行以及最近完成的流程。


阿兹卡班调度python 阿兹卡班界面_上传_13


 

 

8.历史页


    当前正在执行的流程以及完成的执行程序将显示在“历史记录”页面中。提供搜索选项来查找您要查找的执行。或者,您可以在“ 流视图执行”选项卡上查看先前执行的流程。


阿兹卡班调度python 阿兹卡班界面_创建项目_14


9.计划流程


    从用于执行流程的同一个面板中,流程可以通过点击* Schedule *按钮进行排定。


阿兹卡班调度python 阿兹卡班界面_上传_15


    将为预定流保留任何流选项集。例如,如果作业被禁用,则预定流程的作业也将被禁用。


    使用Azkaban 3.3中的新的灵活调度功能,用户可以在Quartz语法之后定义一个cron作业。与Quartz或cron不同的一个重要变化是Azkaban最多以最小的粒度运作。因此,UI中的第二个字段被标记为静态“0”。该灵活的时间表百科解释了细节如何使用。


    安排后,它应该出现在计划页面上,您可以在其中删除计划作业或设置SLA选项。


阿兹卡班调度python 阿兹卡班界面_上传_15


 


10.SLA


    要添加SLA通知或抢占,请单击SLA按钮。从这里您可以设置SLA警报电子邮件。规则可以添加并应用于单个作业或流程本身。如果超过持续时间阈值,则可以设置警报电子邮件,否则流程可能会被自动杀死。


    工作页面 工作组成一个流程的各个任务。要访问作业页面,您可以右键单击流程视图,执行流程视图或项目页面中的作业。

11.任务页面


    在此页面中,您可以查看作业的依赖关系和依赖关系以及作业将使用的全局属性。


 

 12.任务编辑


    单击作业编辑将允许您编辑除特定保留参数(例如type和)以外的所有作业属性dependencies。只有当作业尚未开始运行时,对参数的更改才会影响执行流程。这些覆盖作业属性将被下一个项目上传覆盖。


13.工作历史


    任何工作的重试将显示为executionid.attempt数字。


阿兹卡班调度python 阿兹卡班界面_阿兹卡班调度python_17

14.工作日志


    作业日志存储在数据库中。它们包含所有stdout和stderr作业的输出。


阿兹卡班调度python 阿兹卡班界面_上传_18