第 13 章 部署描述符


流程和规则存储在基于 Apache Maven 的打包中,它们称为知识存档或 KJAR。规则、流程、资产和其它项目工件是由 Maven 构建和管理 JAR 文件的一部分。保存在名为 kmodule.xml 的 KJAR 中的 META-INF 目录的文件可用于定义 KIE 基础和会话。默认情况下,这个 kmodule.xml 文件为空。

每当 KIE 服务器等运行时组件要处理 KJAR 时,它会查找 kmodule.xml 以构建运行时表示。

部署描述符对 kmodule.xml 文件进行补充,并对部署提供精细的控制。这些描述符的存在是可选的,您的部署可以成功进行。您可以使用这些描述符来设置完全技术属性,包括持久性、审计和运行时策略等 meta 值。

这些描述符允许您在多个级别上配置 KIE 服务器,包括服务器级别默认、每个 KJAR 的不同部署描述符和其他服务器配置。您可以使用描述符对默认的 KIE 服务器配置进行简单自定义,可能每个 KJAR。

您可以在名为 kie-deployment-descriptor.xml 的文件中定义这些描述符,并将此文件放到 META-INF 文件夹中的 kmodule.xml 文件。您可以通过将这个默认位置和文件名指定为系统参数来更改这个默认位置和文件名:

-Dorg.kie.deployment.desc.location=file:/path/to/file/company-deployment-descriptor.xml
Copy to Clipboard Toggle word wrap

13.1. 部署描述符配置

通过部署描述符,用户可以在多个级别上配置执行服务器:

  • 服务器级别 :主要级别,以及应用到服务器上部署的所有 KJAR 的主级别。
  • KJAR 级别 :您可以基于每个 KJAR 配置描述符。
  • 部署时间级别 :在部署 KJAR 时应用的描述符。

部署描述符指定的细粒度配置项优先于服务器级别,除了基于集合的配置项目时,会合并它们。层次结构与此类似: 部署时间配置 > KJAR 配置 > 服务器配置

注意

部署时间配置适用于通过 REST API 进行的部署。

例如,如果在服务器级别定义的持久性模式(您可以在服务器级别定义的其中之一)是 NONE,但在 KJAR 级别中指定为 JPA,则实际模式将是 KJAR 的 JPA。如果在 KJAR(或者没有部署描述符的情况下,对于持久性模式指定)的持久性模式,它将回退到服务器级配置,在这种情况下为 NONE (如果没有服务器级别部署描述符,则为 JPA )。

您可以配置什么配置?

高级别的技术配置细节可通过部署描述符来配置。下表列出了它们,以及每个表的可见和默认值。

Expand
表 13.1. 部署描述符
ConfigurationXML EntryPermissible Valuesible Values默认值

运行时数据的持久性单元名称

persistence-unit

任何有效的持久性软件包名称

org.jbpm.domain

审计数据的持久性单元名称

audit-persistence-unit

任何有效的持久性软件包名称

org.jbpm.domain

持久性模式

persistence-mode

JPA, NONE

JPA

Audit 模式

audit-mode

JPA、JMS 或 NONE

JPA

运行时策略

runtime-strategy

SINGLETON、PER_REQUEST 或 PER_PROCESS_INSTANCE

单例

要注册的事件 Listener 列表

event-listeners

有效的监听程序类名称作为 ObjectModel

没有默认值

要注册的任务事件 Listener 列表

task-event-listeners

有效的监听程序类名称作为 ObjectModel

没有默认值

要注册的 Work Item 处理程序列表

work-item-handlers

有效的 Work Item Handler 类指定为 NamedObjectHandler

没有默认值

要注册的全局列表

全局

NamedObjectModel形式提供的有效全局变量

没有默认值

要注册的策略(用于可插拔变量持久性)

marshalling-strategies

有效的 ObjectModel

没有默认值

被授予 KJAR 资源的访问权限所需的角色

required-roles

字符串角色名称

没有默认值

KIE 会话的其他环境条目

environment-entries

有效 NamedObjectModel

没有默认值

KIE 会话的其他配置选项

配置

有效 NamedObjectModel

没有默认值

在远程服务中使用序列化的类

remoteable-class

有效 CustomClass

没有默认值

警告

在生产环境中,不要将 Singleton 运行时策略与 EJB Timer 调度程序(KIE 服务器的默认调度程序)一起使用。这种组合可能会导致 Hibernate 存在负载问题。如果没有特定原因来使用其他策略,则建议按进程实例运行时策略。有关此限制的更多信息,请参阅 Singleton 策略和 EJBTimerScheduler 的 Hibernate 问题

返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2025 Red Hat