国产数据仓库常用ETL调度平台TASKCTL对于Kettle作业类型的转换使用

2022-05-30 15:38:42 浏览数 (4)

Kettle作业转换

TASKCTL默认采用pan命令方式调度kettle转换作业。除此之外,我们还提供了taskctl-plugin-kettle(Soap服务)插件的方式驱动kettle转换。相比原生的pan命令,Soap服务直接驱动kettle核心进行调度。资源消耗更低、速度更快,支持高并发。

安装taskctl-plugin-kettle服务

1.确保安装环境(unix/windows)具备kettle程序目录

2.下载taskctl-plugin-kettle_1.2.3.zip,解压后进入目录,执行install命令

3.按照install程序提示,确定安装信息: ‍

‍4.安装完毕!生成cprunsoapktr.sh文件(注释部分已含调度示例,请查看)。

5.执行startup命令启动插件Soap服务。

注意:

  1. windows需以“管理员身份运行”命令。
  2. 产品官网:www.taskctl.com

在Admin中配置插件

1.拷贝生成的cprunsoapktr.sh至调度服务(或代理)端插件目录,例如:

2.更改ktrjob作业类型的执行程序为新插件。

至此,taskctl-plugin-kettle插件的安装与配置过程完毕。

作业是什么

主要属性xml标签:

.ktrjob:表示是一个kettle转换作业类型

.name: 作业名称,在一个容器(流程或定时器)中不能重复

.progname:被调kettle转换作业的完整路径及名称,如下两种情况(资源库/文件系统):当调用资源库时为“资源库路径/转换名称”;当调用文件系统的转换时为“文件目录/转换文件名”

.para:kettle命名参数,格式为:参数名1=参数值1,参数名2=参数值2,...

.exppara: kettle资源库名,资源库用户名,密码等环境信息,与安装时的配置信息一致。

.jobdesc:作业描述信息

调度示例:

调度范例请参考cprunsoapktr.sh注释部分

作业在哪里运行

  1. 对于单机调度模式来,不用关心作业在哪里运行. 系统缺省就在调度服务本地环境运行。
  2. 如果您的作业不在调度服务环境,而是在远程指定代理环境,我们就需要定义agentid 。
  3. kettle目前不支持无代理模式。hostuser属性无效。

控制策略-作业在什么情况下运行

在TASKCTL中,一旦您完成以上定义,作业就具备基本的运行条件。对绝大数作业定义来说,无需更多作业控制策略的定义。

如果在一个串并流程中,如果您需要对某些作业做更多的控制,比如:错误自动重跑,特别的执行计划等。这时候,就需要设置更多控制属性。

关于ktrjob返回值的申明

对于ktrjob返回值,由ktrjob对应的驱动插件决定。ktrjob执行成功返回0,错误返回1。

1 人点赞