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(); 

drools 5.4.0 を使用しています

誰でも問題を特定するのを手伝ってもらえますか?

4

0 に答える 0