我怎么知道现在正在运行哪个drools规则?

如何解决我怎么知道现在正在运行哪个drools规则?

例如,我加载了很多要运行的drools规则,我怎么知道现在正在运行哪个drools规则?所以我可以知道找出规则

解决方法

假设您谈论的是规则的右侧,您将需要使用 AgendaEventListener。这是一个接口,它定义了一个侦听器,您可以创建该侦听器来监视事件生命周期。有关事件模型的详细信息,请参阅 Drools documentation

最简单的方法是扩展 DefaultAgendaEventListenerDebugAgendaEventListener。这两个类都实现了所有的接口方法。默认侦听器将每个方法实现为“无操作”,因此您可以仅覆盖您关心的方法。 Debug 侦听器使用日志语句实现每个方法,将触发事件的 toString() 记录到 INFO。如果您只是在了解 Drools 生命周期,那么连接各种 Debug 侦听器是观察和了解规则和事件如何在规则中处理的好方法。

(关于侦听器的另一个很酷的地方是它们允许您在满足特定条件时触发的“when”子句中放置断点 - 例如,当创建规则匹配时。总的来说,我发现侦听器是一个很好的选择调试工具,因为它们允许您在 Drools 生命周期的不同部分发生时触发的方法中放置断点。)

无论如何,您要做的是创建一个事件侦听器,然后关注这些特定事件中的一个或多个:

  • 在MatchFired 之前
  • AfterMatchFired
  • 匹配创建

需要注意哪些事件取决于您认为问题出在哪里。

如果您认为问题出在“when”子句(左侧,LHS)中,则 MatchCreated 事件是当 Drools 评估 LHS 并确定此规则对基于触发的有效时触发的在输入数据上。然后,它被有效地放入基于显着性的优先级队列。当该规则在队列中具有最高优先级时,它会被拾取以进行触发——此时触发 BeforeMatchFired 事件;请注意,这是在评估“then”子句(右侧,RHS)之前。然后 Drools 实际上会在 RHS 上进行工作,一旦完成,就会触发 AfterMatchFired

当您的规则执行更新/撤回/等操作时,事情会变得更加复杂——当 Drools 重新评估 LHS 并确定规则不再有效时,您将开始不得不考虑潜在的比赛取消根据工作记忆中的事实触发。但总的来说,这些是您想要开始使用的工具。

我传统上识别长时间运行的规则的方法是在 BeforeMatchFired 内开始计时并在 AfterMatchFired 中停止计时,然后记录生成的规则执行时间。请注意,这里要小心记录 current 规则的执行,按名称跟踪它;如果您的规则扩展了另一条规则,您可能会发现您的执行流程变为 BeforeMatchFired(Child) -> BeforeMatchFired(Parent) -> AfterMatchFired(Parent) -> AfterMatchFired(Child),因此如果您天真地停止共享计时器,您可能会开始遇到问题。我的首选方法是在线程本地或什至线程安全映射实现中按规则名称跟踪计时器,但您可以走任何您喜欢的路线。


如果您使用的是全新版本的 Drools (7.41+),则有一个名为 drools-metric 的新库,您可以使用它来识别慢速规则。我还没有亲自使用这个库,因为最新版本的 Drools 已经开始在次要版本中引入非向后兼容的更改,但这也是一个选项。

您可以在官方文档 here 中阅读有关 drools-metric 的更多信息(您需要向下滚动一点。)您需要进行一些调整,因为该模块仅记录以下情况的实例超过了阈值。我链接到的文档包括您需要导入的 Maven 依赖项、有关配置的信息、一些输出示例以及如何理解它告诉您的内容。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?