drools 内存泄漏

原代码 :

w.insert(user);  
w.fireAllRules();  
w.dispose();  

修改后代码:

FactHandle fact =  w.insert(user);  
w.fireAllRules();  
w.dispose();  
w.retract(fact);

or

w.insert(user);  
w.fireAllRules();  
w.dispose();  
w.retract(w.getFactHandle(user)); 

如上代码所示,w.insert(user)执行完这句代码后会返回一个FactHandle对象,需要WorkingMemory调用retract方法将其从内存中清除掉,不然,即使走完了规则变成了垃圾对象,也无法被垃圾回收器回收,因为WorkingMemory还在引用这个插进去的User对象 。

为什么数据量大的测试环境没有出现oom呢?原因很简单:因为测试环境的数据量虽然大,但能够匹配规则的数据量少,也就是说插入进WorkingMemory中的User对象少,而生产环境正好相反,这就是为什么数据量小反倒还出现oom的原因!

结论:这是因为drools内存泄露导致的内存溢出!

引用自: https://blog.csdn.net/hellozhxy/article/details/80533352

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容