第 5 章 DMN 模型执行
您可以使用 Business Central 在 Red Hat Process Automation Manager 项目中创建或导入 DMN 文件,或者将 DMN 文件打包为您的项目知识 JAR (KJAR)文件的一部分,而无需 Business Central。在 Red Hat Process Automation Manager 项目中实现了 DMN 文件后,您可以通过将其部署到 KIE Server for Remote Access 或直接操作 KIE 容器来执行 DMN 决策服务。还提供了创建和部署 DMN 知识软件包的其他选项,大多数都类似所有知识资产,如 DRL 文件或进程定义。
有关使用项目打包和部署方法包含外部 DMN 资产的详情,请参考 打包和部署 Red Hat Process Automation Manager 项目。
5.1. 直接嵌入 Java 应用程序中的 DMN 调用 复制链接链接已复制到粘贴板!
当知识资产直接嵌入到调用程序中或物理拉取时,KIE 容器是本地的,或使用 KJAR 的 Maven 依赖项进行物理拉取。通常,如果代码版本和 DMN 定义版本之间有紧密关系,则通常直接将知识资产嵌入到项目中。在有意更新并重新部署应用程序后,对决定所做的任何更改都会生效。这种方法的一个优点是,正确的操作不依赖于任何外部依赖项到运行时,这可能是锁定环境的限制。
使用 Maven 依赖项可以进一步的灵活性,因为决策的特定版本可以动态更改(例如,使用系统属性),它可以定期扫描更新和自动更新。这引入了对服务的部署时间的外部依赖项,但在本地执行决策,从而减少在运行时对外部服务的依赖。
先决条件
您已将 DMN 项目构建为 KJAR 工件,并将其部署到 Maven 存储库中,或者已包含您的 DMN 资产作为项目 classpath 的一部分。理想情况下,您已将 DMN 项目构建为可执行模型,以便更有效地执行:
mvn clean install -DgenerateDMNModel=yes
mvn clean install -DgenerateDMNModel=yes
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 有关项目打包和部署以及可执行模型的更多信息,请参阅打包和部署 Red Hat Process Automation Manager 项目。
�程
在客户端应用程序中,将以下依赖项添加到 Java 项目的相关类路径中:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow &
lt;version
> 是项目中当前使用的 Red Hat Process Automation Manager 的 Maven 工件版本(如 7.44.0.Final-redhat-00006)。注意考虑将 Red Hat Business Automation Manager (BOM)依赖项添加到项目
pom.xml
文件,而不是为单个依赖项指定 Red Hat Process Automation Manager <version
>。Red Hat Business Automation BOM 适用于 Red Hat Decision Manager 和 Red Hat Process Automation Manager。当您添加 BOM 文件时,项目中包含了来自提供的 Maven 存储库传输性依赖关系的正确版本。BOM 依赖项示例:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 有关 Red Hat Business Automation BOM 的更多信息,请参阅 RHPAM 产品和 maven 库版本之间的映射是什么?
从
classpath
或ReleaseId
创建 KIE 容器:KieServices kieServices = KieServices.Factory.get(); ReleaseId releaseId = kieServices.newReleaseId( "org.acme", "my-kjar", "1.0.0" ); KieContainer kieContainer = kieServices.newKieContainer( releaseId );
KieServices kieServices = KieServices.Factory.get(); ReleaseId releaseId = kieServices.newReleaseId( "org.acme", "my-kjar", "1.0.0" ); KieContainer kieContainer = kieServices.newKieContainer( releaseId );
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 其它选项:
KieServices kieServices = KieServices.Factory.get(); KieContainer kieContainer = kieServices.getKieClasspathContainer();
KieServices kieServices = KieServices.Factory.get(); KieContainer kieContainer = kieServices.getKieClasspathContainer();
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 使用 model
命名空间和
modelName
从 KIE 容器获取DMNRuntime
,以及对要评估的 DMN 模型的引用:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 为所需模型执行决策服务:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 这个示例打印以下输出:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 如果 DMN 模型之前没有编译为高效执行的可执行模型,您可以在执行 DMN 模型时启用以下属性:
-Dorg.kie.dmn.compiler.execmodel=true
-Dorg.kie.dmn.compiler.execmodel=true
Copy to Clipboard Copied! Toggle word wrap Toggle overflow