50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

Tom Baeyens 谈过程虚拟机

  • 2008-05-04
  • 本文字数:2419 字

    阅读完需:约 8 分钟

随着 jBPM 过程虚拟机(Process Virtual Machine)最近alpha 测试版的发布,JBoss 距离实现一个支持多定义语言的过程执行语言的目标又进了一步。这次发布也标志着jBPM 受到关注的增多,最近还提供了一个更新站点。InfoQ 就这个项目,以及 PVM 如何改变 BPM 领域采访了项目的带头人 Tom Baeyens。InfoQ:您能向 InfoQ 的读者介绍一下 PVM 概念的历史和目的吗?****Tom:过程虚拟机(Process Virtual Machine)是我们在 jBPM 探索过程中核心概念的最终产物。

jBPM 一开始使用被称为 jPDL 的单一过程语言,但是在成为 JBoss 一部分后不久,用户就一直问我们是否也能支持 BPEL。那时我意识到 jPDL 实现和 BPEL 有许多重叠的地方。自从那时起,我们就一直从过程语言特殊部分中抽取公共部分。

jBPM 3 已经有了能工作的全部概念,它能运行多种过程语言,如天生就支持 jPDL 和 BPEL。但是缺点是它仍是一个大代码库,不是真正的模块。因为 BPM 和工作流领域完全都是各自为政,多种过程语言的需要日益明显。因此,我们需要一个更模块化的方法。

那就是过程虚拟机出现的原因。它是一个用来构建和执行过程图的代码库。过程语言的本地实现可以构建于过程虚拟机之上。此外,它可以运行在任何Java 环境之内,不论它是标准Java、企业Java,还是SEAM 或Spring。

InfoQ:为什么这很重要?Tom:一方面,业务过程管理(BPM)和工作流领域完全都是各自为政。有很多针对特定用例和环境的不同类型的过程语言。这和领域特定语言(DSL)有些相似;不是一门语言就可以把全部事情都搞定。目前,所有这些语言都有一套自己的单片式(monolithic)引擎,这并不实用,而且它们也很难包含到一个应用之中。

过程虚拟机提供了一个简单的统一结构来使这些过程语言运行在一个核心技术之上。

另一方面,Java 领域也同样是分裂的。与那些必须在一个单独服务器上隔离运行的传统过程引擎不同,过程虚拟机可以内嵌到你的应用中运行,不管什么Java 环境。这大大降低了使用过程技术的项目的门槛,因为过程持久化可以被透明地与应用持久化集成。

InfoQ:应用开发人员需要使用过程虚拟机本身工作吗? Tom:绝大多数的应用开发人员不用使用过程虚拟机本身工作,而是使用构建在它之上的一种过程语言,如 jPDL、BPEL 或 XPDL。

但是,应用开发人员了解过程虚拟机基本概念还是很重要的。就像开发人员为了使用关系数据库而需了解表、列、主键和 SQL 查询基本概念一样,他们需要了解过程虚拟机概念,如过程定义、执行异常和异步延拓(continuation)。

InfoQ:Bull 现在已经与 JBoss 合作来支持 PVM 概念——你们在和其他合作伙伴共事吗?

Tom:Bull 的确和我们就过程虚拟机进行合作。他们贡献了过程虚拟机中的一些基础功能,并主导 BPEL 和 XPDL 活动实现。还有些其他公司尚在联络中,但是很遗憾我们还不能透露他们。但是我们看到明显的迹象表明,过程虚拟机将巩固 BPM 领域中的 Java 的势力。
InfoQ:到现在为止,有哪些主要挑战是你们不得不克服的?

Tom:目前关于分析、实现和服务编制存在的混淆。对于过程虚拟机的应用,我们注意到了 3 个清晰分离的用例。让我们来讨论它们,并强调哪种过程语言最适合哪个用例:

  1. 对实现的分析:这是当今单纯的(pure-play)BPM 套件的目标。从一个分析图开始,然后将其转换成可执行的软件。许多传统厂商试图用大量魔法掩盖分析过程图和可执行软件间的重大区别。 这暗示着:图是负责需求的非技术人员和负责自动化的技术人员之间重要的沟通工具。但是大体上,没有技术手段能够从非技术人员的输入产出可用于生产环境的软件。

    要使分析人员和开发人员之间能够协作,可执行过程语言就必须足够灵活完全匹配分析图。像可自定义活动实现和事件监听器这样的特性对于确保分析人员在图变得可执行之后仍能认出它来说至关重要。jPDL 非常适合这个用途。它还提供了一个与 Java 技术的清晰集成,一个开发人员喜欢的简洁、易读的 XML 语法。XPDL 也支持这个用例。XPDL 的语法更加复杂和缺乏可读性,但是它的移植性更好,因为更多的厂商正在采用这种标准,虽然缓慢但是稳定。

  2. 异步 Java 架构:就使用异步架构来说,Java 的确没提供吸引眼球的解决方案。事实上,这是个大麻烦。 一方面,企业平台有用于异步消息的 JMS 和 EJB 定时器。但是,那些都非常的底层。你需要很多部署描述符来支持一个长期运行的过程,非常麻烦。而且接下来,关于事物如何关联的整体视图完全不见了。通过 jPDL,这个整体视图清晰可见,而且热部署就像做饼一样容易。只需在一个图形工具中重新配置图中的变迁(transition)并重新部署,而不是花上好几个小时书写麻烦的企业部署描述符。

    另一方面,标准 Java 平台完全不支持异步架构。jPDL 和标准 Java 平台结合得非常紧密,它利用了来自过程虚拟机的工作执行器(job executor)来提供异步延拓(continuation)和定时器。

因此现在,由于有了基本的过程虚拟机基础设施,一个单一 jPDL 过程就可捕获人、Java 代码和其他事物的异步编制,并可使那个逻辑在标准和企业 Java 环境间可移植。
3. 服务编制:对于服务编制来说,BPEL 已经广泛被接受,并成为被支持的标准。它操作在企业服务总线(ESB)级别,因此它是一种集成技术。一个 BPEL 过程可以(过分简化的)被认为是 Web 服务级别的脚本。WSDL 服务可通过 BPEL 被描述成粗粒度的服务。

InfoQ:读者可以在哪里找到关于 PVM 的更多信息?Tom:首先,6 月 6 号在都柏林会举办一个 jBPM 社区日的活动。这是一次 jBPM 核心开发人员、合作伙伴、客户和其他只是想更多了解 jBPM 的人之间绝佳的沟通机会。活动是免费的,在一个周五下午。欲知详情,请查看 jBPM 社区日 Wiki 页或发邮件至 dublin@jbpm.org

其次,对于那些缺乏耐心的读者,这儿有一个已经手把手地解释如何使用它来构建活动和开始运行它的 PVM 手册

最后,这儿还有一篇 InfoQ 文章“过程组件模型:下一代工作流?”,它已于最近发布,给出了关于这一主题的更多背景资料。

查看英文原文: Tom Baeyens on the Process Virtual Machine

2008-05-04 04:171521
用户头像

发布了 255 篇内容, 共 66.8 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

必看!10 款好用的 AI 工具,个人与企业都能用

Techinsight

AI GENTS

2025 企业数字化新战场:DeepSeek 本地知识库的价值

Techinsight

谷歌A2A vs Anthropic MCP协议对比解析

测试人

人工智能

有了AI Agents,RPA还有生存空间吗?

Techinsight

RPA AI Agents

普通人如何玩转 DeepSeek?本地部署攻略来了

Techinsight

AI 如何为 RPA 赋予 “超能力”及避坑指南

Techinsight

RPA RPA评测 RPAxAI RPA Agent RPA智能体

海外云手机怎样帮企业省钱玩转海外社媒?

Ogcloud

云手机 海外云手机 海外社媒运营 海外社媒推广

Bilibili、中电信人工智能科技、商汤科技、联通云等正式加入Volcano社区用户组

华为云原生团队

云计算 容器 云原生 Volcano

2025 爆款 AI 工具,总有一款适合你

Techinsight

2025多链代币开发全景指南:从BSC到TON的实战策略与技术选型

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 公链开发代币开发

OceanBase如何支持应用多活

陈一之

高可用架构 oceanbase 应用多活

BeeWorks Meet更适合企业内部使用的原因

BeeWorks

即时通讯 IM 私有化部署 局域网视频软件

DeepSeek 搭配这些 AI 工具,PPT、图片、视频、文案秒出!

Techinsight

AI智能体:高效工作的超级助手,一文带你深度解析

Techinsight

AI Agent智能体是什么,一文看懂!

Techinsight

智能体领域:C端产品潜力显现,企业级产品各显神通

Techinsight

agent

博睿数据受邀出席2025GOPS全球运维大会深圳站!解锁LLM技术在智能运维中的深度应用

博睿数据

赋能新质生产力·智创产业新生态|2025青岛国际人工智能展会

AIOTE智博会

人工智能展览会 人工智能展会 人工智能展

Taro on Harmony :助力业务高效开发纯血鸿蒙应用

京东零售技术

签约!亚太物业标杆启胜物业携手用友采购云,共启数智采购新旅程

用友BIP

深度剖析!企业和个人本地部署 DeepSeek 的真实原因与利弊

Techinsight

HR黑科技:AI+RPA+飞书,智能招聘全流程自动化,效率提升300%!

Techinsight

RPA AI Agent

RPA+AI技术好在哪里?

Techinsight

RPA RPAxAI RPA Agent RPA智能体

RPA 技术赋能电商运营:从数据抓取到订单处理的全流程自动化实践

Techinsight

电商

别再用“过时源码”做陪玩小程序!这版代码让用户留存率飙升60%的3个狠招

DUOKE七七

如何利用科学的预算管理为企业释放更多价值

智达方通

企业管理 全面预算管理 预算管理

2025 年 HR 必看!这 8 款数字化管理软件如何重塑企业效率?

Techinsight

千万级数据秒级响应!碧桂园基于 EMR Serverless StarRocks 升级存算分离架构实践

阿里云大数据AI技术

大数据 阿里云 Serverless EMR

人工智能经济爆发!哪些行业将迎来巨变?

Techinsight

2025 国内 RPA 选型秘籍:从推荐到避坑,一文读懂

Techinsight

常用的RPA软件有哪些?

Techinsight

RPA RPA Agent RPA智能体

Tom Baeyens谈过程虚拟机_Java_Gavin Terrill_InfoQ精选文章