Drools骆驼多次ksession没有射击

时间:2013-09-22 18:54:46

标签: drools rule-engine drools-flow

我正在使用drools 5.6。在camel-server.xml中,我的路由定义为:

<route>
   <from uri="cxfrs://bean://rsServer"/>
   <policy ref="droolsPolicy">
     <unmarshal ref="xstream-json" />
     <to uri="drools:node1" />
     <marshal ref="xstream-json" />
   </policy>
</route>

我没有定义一个ksession。然后在我的knowledge-service.xml中,我有2个会话(由用户定义)指向不同的DRL文件。这些导入相同的常见DRL文件

<drools:kbase id="kbase1" node="node1">
<drools:resources>
  <drools:resource ref="ruletemplate" />
  <drools:resource  type="DRL" source="classpath:7.drl"/>
</drools:resources>
</drools:kbase>
<drools:ksession id="ksession-7" type="stateless" kbase="kbase1" node="node1"/>
<drools:kbase id="kbase2" node="node1">
  <drools:resources>
  <drools:resource ref="ruletemplate" />
  <drools:resource type="DRL" source="classpath:12.drl"/>
</drools:resources>
</drools:kbase>
<drools:ksession id="ksession-12" type="stateless" kbase="kbase2" node="node1"/>

这个想法是ksession将在传入的JSON请求中定义:

{"batch-execution": { "lookup":"ksession-12", "commands": [ { "insert": { "out-identifier": ...

服务器启动并更改7到12之间的查找工作。然而,无论我先运行什么查找都是实际触发的唯一规则。因此,如果我启动服务器并运行ksession-7它将成功运行,然后更改为ksession-12没有任何反应(不会在12.drl中调试)

如果我然后重新启动服务器并首先运行12它将成功运行,然后更改为ksession-7并且没有任何反应

我对此感到困惑,并相信我错过了一些东西。我的目标是为每个用户提供一个包含特定规则的通用规则模板。任何人都可以帮助指导我为什么没有正确指导(或不处理)

编辑:添加示例

t1.drl:     包org.company.t1.rules     import org.test。*

rule "check patients age" dialect "mvel"
when
    $p : Patient( age >= 10)
then
    System.out.println("t1 - age greater then 10")
    $ca = new Message("age greater then 10")
    $p.alerts.add($ca)
end

t2.drl:

package org.company.t2.rules
import org.test.*

rule "check patients age" dialect "mvel"
when
    $p : Patient( age >= 15)
then
    System.out.println("t2 - age greater then 15")
    $ca = new Message("age greater then 15")
    $p.alerts.add($ca)
end

ruletemplate.drl:

package  org.test

declare Message
  text : String
end

declare Patient
    id:String
    age : Integer
    alerts : java.util.ArrayList
end

rule "setup rule for alerts" dialect "mvel" salience 100
when
  $p : Patient()
then
  System.out.println("initialize array")
  $p.alerts = new java.util.ArrayList();
end

知识的server.xml:

<drools:resource id="ruletemplate" type="DRL" source="classpath:ruletemplate.drl" />

 <drools:kbase id="kbase5" node="node1">
  <drools:resources>
    <drools:resource ref="ruletemplate" />
    <drools:resource  type="DRL" source="classpath:t1.drl"/>
  </drools:resources>
 </drools:kbase>

<drools:kbase id="kbase6" node="node1">
  <drools:resources>
    <drools:resource ref="ruletemplate" />
    <drools:resource  type="DRL" source="classpath:t2.drl"/>
  </drools:resources>
</drools:kbase>

<drools:ksession id="ksession5" type="stateless" kbase="kbase5" node="node1"/>
<drools:ksession id="ksession6" type="stateless" kbase="kbase6" node="node1"/>

第一个有效的请求:

   {"batch-execution": { "lookup":"ksession5", "commands": [ { "insert": { "out-identifier": "patient", "object": { "org.test.Patient":[{"age":16}]}}},{"fire-all-rules": ""}]}}


{"execution-results":{"results":{"result":{"identifier":"patient","value":{"org.test.Patient":{"age":16,"alerts":{"org.test.Message":{"text":"age greater then 10"}}}}},"fact-handle":{"identifier":"patient","external-form":"0:2:537549803:537549803:2:DEFAULT"}}}}

请求2 :(除非在服务器重启后首先运行,否则不起作用:

{"batch-execution": { "lookup":"ksession6", "commands": [ { "insert": { "out-identifier": "patient", "object": { "org.test.Patient":[{"age":16}]}}},{"fire-all-rules": ""}]}}


{"execution-results":{"results":{"result":{"identifier":"patient","value":{"org.test.Patient":{"age":16}}},"fact-handle":{"identifier":"patient","external-form":"0:2:552327108:552327108:2:DEFAULT"}}}}

Tailing catalina.out显示t1的调试器输出,因为它首先运行,但t2上没有任何内容

1 个答案:

答案 0 :(得分:0)

你在插什么?那里有什么样的规则? 可能是第一次运行一切运行良好,第二次运行后面崩溃?