BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

文章:在SOA中实现业务规则和业务流程

| 作者 Boris Lublinsky 关注 0 他的粉丝 , Didier Le Ti 关注 0 他的粉丝 ,译者 荣浩 关注 0 他的粉丝 发布于 2007年11月17日. 估计阅读时间: 2 分钟 | Google、Facebook、Pinterest、阿里、腾讯 等顶尖技术团队的上百个可供参考的架构实例!

SOA的目的在于帮助企业提高其业务敏捷性,使其能够快速满足实际业务所发生的变化。在企业应用中,变更最为频繁的就是业务规则和业务流程。正是由于这些变更,故而有必要在实现和修改业务规则以及业务流程时保持相当的灵活性,从而使企业在激烈的竞争中赢得一席之地。

然而,在实际的应用中,人们对业务规则和业务流程却有着种种的误解,经常把两者混淆在一起。在本文中,作者首先归纳了这些误解。接着文章对业务规则和业务流程的概念进行了详细的描述:它们的定义,它们能做什么,它们的优点。“业务规则可以被看作是业务实践的一个集合,定义实际的实现——业务逻辑。这种逻辑的实现经常可以通过使用专门的工具进行简化——业务规则语言和业务规则引擎。”“业务流程定义可以被看作是对一组相互关联的活动的编排。类似于业务规则的情况,可以利用业务流程DSL和专门的业务流程引擎来实现”。

业务规则与业务流程之间存在着哪些异同?我们该如何选择?它们在SOA中又各自扮演着什么角色?作者提出了自己的观点。由业务流程实现业务服务的编排,而业务规则作为服务实现的一部分实现业务组件,业务组件则负责对服务内部其他的组件进行编排。

实际上现代的业务流程引擎一般都提供有执行简单规则的功能,这一功能构建在业务流程语言中,或者通过调用通用的语言来实现。这一功能是否够用?作者认为如果业务流程中的业务规则非常复杂并且频繁变更,那么它们一般需要利用规则引擎从流程中提取,并被实现为一项独立的服务。

文章最后对业务流程和规则引擎在SOA实现中的典型用法进行了总结:用规则引擎作为服务实现的一部分,并利用业务流程引擎对服务进行编排。

阅读全文:在SOA中实现业务规则和业务流程

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

BMP? by Gavin Wang

许多实践者将业务规则当作更广义的业务流程管理(BMP)的一部分

should change to

许多实践者将业务规则当作更广义的业务流程管理(BPM)的一部分

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

1 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT