为什么我的KnowledgeAgent没有考虑规则变更?

时间:2013-01-16 20:57:13

标签: drools rules business-rules

我有一个简单的Drools Expert KnowledgeAgent用例。我正在使用Drools 5.3.0.Final,我的规则已经在Guvnor 5.3.0.Final编译。

我的变更集xml文件如下所示:

   <add>
       <resource type="PKG" source="http://ssmdeoasd01.susalud.com:7777/drools-guvnor/org.drools.guvnor.Guvnor/package/co.com.sura.seguros.adultomayor.consultas/LATEST"/>
   </add>

Tha PKG包含来自单个简单DTABLE的规则。

当我更改DTABLE并将其上传到Guvnor时(当应用程序仍在运行时),Drools Expert确实确定了更改,但不应用它。控制台如下所示:

Compilando reglas ...
Reglas compiladas ...
Tiempo de compilacion de reglas: 0 ms
Obteniendo manager ...
Manager obtenido ...
Obteniendo sesión de conocimiento ...
listKnowledgePackages.size(): 1
Sesión de conocimiento obtenida ... 
3 Padre
2 Hermanos
1 Conyuge
[2013-01-16 15:54:17,670:debug] ResourceChangeScanner attempt to scan 1 resources
[2013-01-16 15:54:17,684:debug] ResourceChangeScanner modified resource=[UrlResource path='http://ssmdeoasd01.susalud.com:7777/drools-guvnor/org.drools.guvnor.Guvnor/package/co.com.sura.seguros.adultomayor.consultas/LATEST'] : 1358369287000 : 1358369637000
[2013-01-16 15:54:17,684:debug] ResourceChangeNotification received ChangeSet notification
[2013-01-16 15:54:17,684:debug] ResourceChangeScanner thread is waiting for 60 seconds.
[2013-01-16 15:54:17,684:debug] ResourceChangeNotification processing ChangeSet
[2013-01-16 15:54:17,684:debug] ResourceChangeNotification ChangeSet modified resource=[UrlResource path='http://ssmdeoasd01.susalud.com:7777/drools-guvnor/org.drools.guvnor.Guvnor/package/co.com.sura.seguros.adultomayor.consultas/LATEST'] for listener=org.drools.agent.impl.KnowledgeAgentImpl@10655dd
[2013-01-16 15:54:17,686:debug] ResourceChangeNotification thread is waiting for queue update
Compilando reglas ...
Reglas compiladas ...
Tiempo de compilacion de reglas: 0 ms
Obteniendo manager ...
Manager obtenido ...
Obteniendo sesión de conocimiento ...
listKnowledgePackages.size(): 1
Sesión de conocimiento obtenida ... 
3 Padre
2 Hermanos
1 Conyuge

即使KnowledgeAgent识别出更改,规则仍然编译相同,并且结果中不会反映任何更改。

我没有针对KnowledgeAgent的特定配置,也没有特定的扩展。我使用了默认的侦听器,而是使用了。

为什么会这样?

1 个答案:

答案 0 :(得分:0)

我犯了一个错误。

我正在使用现有的KnowledgeBase构建代理。然后,当代理程序被实例化时,我从该代理程序获取基础并保留对该基础的引用,以便始终从该基础获取会话。我认为如果代理中的基础发生了变化,那么我从代理商那里获得的基数也发生了变化。

然后,当Guvnor中的规则发生变化时,代理确实完成了它的工作并重新创建了它的知识库,但是因为我总是引用代理实例化后立即获得的基础并从旧知识库获取会话然后执行的规则是旧基地的规则。

现在引用正常,规则中的更改会反映在执行中:)