2

我正在使用 jBoss 规则。但是在使用 JBoss 规则后我遇到了内存问题。使用分析工具,我收集了堆转储,结果如下:

    One instance of "org.drools.reteoo.ReteooStatefulSession" loaded by 
    "sun.misc.Launcher$AppClassLoader @ 0x7f899fdb6d88" occupies 657,328,888 (78.91%) bytes. 
    The memory is accumulated in one instance of "org.drools.reteoo.ReteooStatefulSession" 
    loaded by "sun.misc.Launcher$AppClassLoader @ 0x7f899fdb6d88". 

    Keywords 
    sun.misc.Launcher$AppClassLoader @ 0x7f899fdb6d88 
    org.drools.reteoo.ReteooStatefulSession

下面给出了我用于 JBoss 规则的代码。

            kbase= KnowledgeBaseFactory.newKnowledgeBase(); 
            ksession= kbase.newStatefulKnowledgeSession(); 
            final String str = CISMSRemotingUtils.getFullConfigFilePath("change-set.xml") ; 
            final String filePath = str.replaceAll(" ", "%20"); 
            aconf = KnowledgeAgentFactory .newKnowledgeAgentConfiguration(); 
            aconf.setProperty("drools.agent.newInstance", "false"); 
            kagent = KnowledgeAgentFactory.newKnowledgeAgent( "Agent", aconf); 
            kagent.applyChangeSet( ResourceFactory.newFileResource(filePath) ); 
            kbase = kagent.getKnowledgeBase(); 
            ksession= kbase.newStatefulKnowledgeSession(); 
            sconf =ResourceFactory.getResourceChangeScannerService().newResourceChangeScannerConfiguration(); 
            sconf.setProperty( "drools.resource.scanner.interval", "3600"); 
            ResourceFactory.getResourceChangeScannerService().configure( sconf ); 
            ResourceFactory.getResourceChangeNotifierService().start(); 
            ResourceFactory.getResourceChangeScannerService().start(); 

这段代码在类构造函数中给出,并且在这个类中触发规则

            ksession.insert(data); 
            ksession.fireAllRules(); 

我正在使用流口水 5.4.0

谁能帮我找出问题?

4

0 回答 0