到目前为止,我还没有找到在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会进行增量更新和保留。
程式码片段:
// 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调用触发一个新的源主题应该由一个现有的处理器处理。源主题存储在数据库中并用于生
在运行时添加到当单击时。 我使用以下代码: 但是在中没有显示任何。