当前位置: 首页 > 面试题库 >

Drools 6:向正在运行的KieSession添加规则

徐洛华
2023-03-14
问题内容

到目前为止,我还没有找到在Drools
6.0.0中将规则添加到正在运行的KieSession的最佳方法(即以最小的开销),而仍然将我的事实保留在KieSession中。在Drools
5中,当更改KBase时更新了KSession,但对于Drools
6而言却并非如此,因为我的规则未在KieBase中创建。有没有一种方法可以替换整个KieFileSystem中的整个KieModules或Jars。我认为应该有一个简单的方法

你们有个主意吗?

问候


问题答案:

是的,支持用例,但重要的是要了解Drools
6引入了版本化可部署工件(经过精加工的kjars)的概念。换句话说,一旦使用版本X创建了一个jar,它就应该是不可变的。如果要向kjar中定义的kbase添加/删除规则,则应创建另一个kjar版本X
+ 1。可以在磁盘上将其作为真实的jar物理创建,也可以在内存中创建。

了解kjar是不可变的源工件以及kcontainer是实例化kjar并允许使用其kbase和ksessions的容器这一概念也很重要。

如果理解了这一点,那么您要做的就是实例化版本X的容器,并且当您想要更改kbase时,调用容器updateToVersion(…)方法以将其更新为新版本。就像在Drools
5中一样,KBases和KSessions会进行增量更新和保留。

此处的单元测试:[https]( https://github.com/droolsjbpm/drools/blob/master/drools-
compiler/src/test/java/org/drools/compiler/integrationtests/IncrementalCompilationTest.java#L158)
//github.com/droolsjbpm/drools/blob/master/drools-
compiler/src/test/java/org/drools/compiler/integrationtests/IncrementalCompilationTest.java#L158

程式码片段:

    // work with version 1.0.0
    ReleaseId releaseId1 = ks.newReleaseId("org.kie", "test-upgrade", "1.0.0");
    ...

    // Create a session and fire rules
    KieContainer kc = ks.newKieContainer( releaseId1 );
    KieSession ksession = kc.newKieSession();
    ksession.insert(new Message("Hello World"));
    ...

    // upgrade to version 1.1.0
    ReleaseId releaseId2 = ks.newReleaseId("org.kie", "test-upgrade", "1.1.0");
    kc.updateToVersion(releaseId2);

    // continue working with the session
    ksession.insert(new Message("Hello World"));
    ...


 类似资料:
  • 到目前为止,我还不知道在Drools 6.0.0中向正在运行的Kie会话添加规则并仍然将我的事实保存在Kie会话中的最佳方法(意味着以最小的开销)。在Drools 5中,当KBase更改时,K会话会更新,但Drools 6似乎并非如此,因为我的规则不是在KieBase中创建的。有没有一种方法可以在不更换KieFileSystem中的整个KieModules或Jars的情况下做到这一点。我认为应该有

  • 我尝试在从KieBase中删除规则后重新创建KieSession,但删除的规则仍在触发。 我使用以下代码创建了一个KieBase并删除了一条规则: 但是当我根据ksesion1评估一个事实时,rule1仍然在触发。如何将编辑后的KieBase重新加载到新会话中?

  • 是否可以为已经运行的pod额外公开端口?如果我创建一个新的pod,我会为它们提供podman pod创建...-p 8080:80。 但是,我不想扔掉我的pod,只需修改它以暴露另一个端口。

  • 有没有什么方法可以动态编辑加载到Drools中的规则,而不需要重新加载新的DRL文件? 我们试图使用Drools作为规则引擎,但在我们的用例中,规则的添加和删除非常频繁,我们希望避免每次发生这种情况时都必须重新加载整个.drl文件。

  • 是否可以将另一个源主题添加到正在运行的kafka streams java应用程序的现有拓扑中。基于javadoc(https://kafka.apache.org/23/javadoc/org/apache/kafka/streams/kafkastreams.html),我猜答案是否定的。 我的用例:REST api调用触发一个新的源主题应该由一个现有的处理器处理。源主题存储在数据库中并用于生

  • 在运行时添加到当单击时。 我使用以下代码: 但是在中没有显示任何。