Informatica_(4)工作流

三、workflow执行、监控
workflow是PowerCenter的执行单元;
一个workflow包括一个或者多个session(或task)。

1.session
session是mapping的实例化。
session是给mapping提供配置文件的场所或机制。
有了这些配置信息,mapping就可以执行了,所以说session是mapping的一个可执行实例。
session的两种类型:Reusable session(可重复使用)和非Reusable session(不可重复使用)。
1.1 Reusable session(可重复使用session)
创建一次,可以被多次重用。
选中“Task Developer”,打开菜单“Tasks--》create”,输入session名点“create”,选择对应的mapping.
Reusable session可用以多个workflow或者worklet。

1.2 非Reusable session(不可重复使用session)
先创建workflow,再创建session。
选中“workflow designer”,打开菜单“workflows--》create”,输入workflow名点“OK”,workflow的起始点“Start”创建成功;
再在workflow的工作区内创建session,即非Reusable session。
非Reusable session可以转换为Reusable session,双击session,选中“make reuseable”。

2.workflow
2.1 并行执行
一个workflow同时链接多个session,并且多个session之间没有依赖关系,可以并行执行以提升效率。
2.2 串行执行
一个workflow同时链接多个session,并且多个session之间存在依赖关系,需要按照依赖关系顺序依次执行。
例外处理:对于后一个session依赖于前一个session的运行状态时,双击连线,增加条件“$session1.status=succeeded”
2.3 调度:周期性的定时运行workflow
在“workflow designer”中打开一个workflow,打开菜单“workflows--》edit--》Scheduler Tab”,选中"Non Reuseable",点“应用”,
设置完成后,需要执行Schedule workflow。

3.worklet
worklet也是task/session的集合(和workflow一样);
worklet不能单独运行,只能放在workflow中,作为workflow的子集运行(和workflow的区别)。
worklet可以被一个或多个workflow调用。
选择“worklet designer”,打开菜单“worklets-->create”,
worklets虽然也有“Start”,但他不可以独立执行。
只有将worklets加入到workflow中才可以被执行。

4.command
command是workflow中的一个Task。
可以使用command调用外部命令或者shell。

5.control
control task 提供了通过workflow/worklet内的任务,控制workflow/worklet状态的能力。
当关键任务失败时,可以将进程指向control task,
在control task内设置控制选项。

6.发送e-mail
6.1 配置发送e-mail
需要配置集成服务确保其能够发送邮件;
在PowerCenter服务器端安装PowerCenter支持的发送邮件e-mail的客户端;
--单独安装邮件服务器。
PowerCenter是否能发送邮件事实上和(具体的)邮件服务器无关,
重要的是邮件客户端是否支持相关的协议,并且该客户端可以支持相应的邮件服务器。

6.2 在workflow中使用e-mail
1.在workflow/worklet中发送e-mail
2.在session的components Tab中发送e-mail
3.在workflow的General Tab中发送e-mail

7.event tasks
event raise触发事件,
event wait等待event raise触发的事件,
一旦获得了正在等待的时间,就会触发其后续的Task。
7.1 用户自定义事件使用
用户自定义事件需要在workflow中定义一个Event对象。
首先在workflow中定义事件。菜单“workflows-->edit”,选中events Tab,增加一个事件(EventX);
在workflow中可以使用event raise和event wait;
在event raise中配置需要抛出的事件(EventX);
在event wait中配置需要监听的事件(EventX);
当事件(EventX)被event raise抛出后,event wait将监听到事件(EventX),从而触发后续的流程。
7.2 预定义事件使用
预定义事件是一种File-Watch事件,即event wait等待一个触发文件(.trigger文件)。
由人为手动触发,仅使用event wait任务监听是否发现触发文件(.trigger文件)即可;
当发现该文件后,event wait任务触发后续的流程。
触发后触发文件(.trigger文件)不会被自动删除,
在event wait的属性页签配置delete filewatch file选项即可删除触发文件(.trigger文件)

8.timer
timer是一个定时任务,它可以指定后续任务的启动时间。
在timer页签指定时间,包括绝对时间和相对时间。
绝对时间可以使用物理时间,也可以用变量指定。
相对时间是指定距离上一个任务启动的时间间隔。

9.decision
decision Task用于多个前置任务的与或非判断。
“$s_1.Status=succeeded OR $s_2.Status=succeeded OR $s_2.Status=succeeded”
即前3个session只要有一个成功就执行后续session。

10.assignment
assignment

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值