1

drools 5 のより包括的なクイック スタートはありますか。単純な Hello World .drl ルールを実行しようとしていましたが、おそらく javac/java だけを使用して、ant スクリプトを使用して実行したかったのです。

次のエラーが表示されます: 注: Eclipse やその他の IDE なしで完全に実行しているわけではありません:

drools 5 のより包括的なクイック スタートはありますか。単純な Hello World .drl ルールを実行しようとしていましたが、おそらく javac/java だけを使用して、ant スクリプトを使用して実行したかったのです。

次のエラーが表示されます: 注: Eclipse やその他の IDE なしで完全に実行しているわけではありません:

test:
     [java] Exception in thread "main" org.drools.RuntimeDroolsException: Unable to load d
ialect 'org.drools.rule.builder.dialect.java.JavaDialectConfiguration:java:org.drools.rule
.builder.dialect.java.JavaDialectConfiguration'
     [java]     at org.drools.compiler.PackageBuilderConfiguration.addDialect(PackageBuild
erConfiguration.java:274)
     [java]     at org.drools.compiler.PackageBuilderConfiguration.buildDialectConfigurati
onMap(PackageBuilderConfiguration.java:259)
     [java]     at org.drools.compiler.PackageBuilderConfiguration.init(PackageBuilderConf
iguration.java:176)
     [java]     at org.drools.compiler.PackageBuilderConfiguration.<init>(PackageBuilderCo
nfiguration.java:153)
     [java]     at org.drools.compiler.PackageBuilder.<init>(PackageBuilder.java:242)
     [java]     at org.drools.compiler.PackageBuilder.<init>(PackageBuilder.java:142)
     [java]     at org.drools.builder.impl.KnowledgeBuilderProviderImpl.newKnowledgeBuilde
r(KnowledgeBuilderProviderImpl.java:29)
     [java]     at org.drools.builder.KnowledgeBuilderFactory.newKnowledgeBuilder(Knowledg
eBuilderFactory.java:29)
     [java]     at org.berlin.rpg.rules.Rules.rules(Rules.java:33)
     [java]     at org.berlin.rpg.rules.Rules.main(Rules.java:73)
     [java] Caused by: java.lang.RuntimeException: The Eclipse JDT Core jar is not in the
classpath
     [java]     at org.drools.rule.builder.dialect.java.JavaDialectConfiguration.setCompil
er(JavaDialectConfiguration.java:94)
     [java]     at org.drools.rule.builder.dialect.java.JavaDialectConfiguration.init(Java
DialectConfiguration.java:55)
     [java]     at org.drools.compiler.PackageBuilderConfiguration.addDialect(PackageBuild
erConfiguration.java:270)
     [java]     ... 9 more
     [java] Java Result: 1

...
...

javac および java ターゲットに次のライブラリを含めます。

 <path id="classpath">
     <pathelement location="${lib.dir}" />
     <pathelement location="${lib.dir}/drools-api-5.0.1.jar" />
     <pathelement location="${lib.dir}/drools-compiler-5.0.1.jar" />
     <pathelement location="${lib.dir}/drools-core-5.0.1.jar" />
     <pathelement location="${lib.dir}/janino-2.5.15.jar" />
 </path>

エラーをスローしている Java コードを次に示します。java.compiler コードをコメントアウトしましたが、それも機能しませんでした。

public void rules() {

/*
final Properties properties = new Properties(); 
properties.setProperty( "drools.dialect.java.compiler", "JANINO" ); 
PackageBuilderConfiguration cfg = new PackageBuilderConfiguration( properties ); 
JavaDialectConfiguration javaConf = (JavaDialectConfiguration) 
cfg.getDialectConfiguration( "java" ); 
*/
final KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();

// this will parse and compile in one step
kbuilder.add(ResourceFactory.newClassPathResource("HelloWorld.drl", Rules.class), ResourceType.DRL);

// Check the builder for errors
if (kbuilder.hasErrors()) {
    System.out.println(kbuilder.getErrors().toString());
    throw new RuntimeException("Unable to compile \"HelloWorld.drl\".");
}

// Get the compiled packages (which are serializable)
final Collection<KnowledgePackage> pkgs = kbuilder.getKnowledgePackages();

// Add the packages to a knowledgebase (deploy the knowledge packages).
final KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase();
kbase.addKnowledgePackages(pkgs);

final StatefulKnowledgeSession ksession = kbase.newStatefulKnowledgeSession();
ksession.setGlobal("list", new ArrayList<Object>());

ksession.addEventListener(new DebugAgendaEventListener());
ksession.addEventListener(new DebugWorkingMemoryEventListener());

// Setup the audit logging
KnowledgeRuntimeLogger logger = KnowledgeRuntimeLoggerFactory.newFileLogger(ksession, "log/helloworld");

final Message message = new Message();
message.setMessage("Hello World");
message.setStatus(Message.HELLO);
ksession.insert(message);

ksession.fireAllRules();
logger.close();
ksession.dispose();

}

...

ここでは、fork を true に設定しているため、Ant は関係ないと思います。

 <target name="test" depends="compile">
     <java classname="org.berlin.rpg.rules.Rules" fork="true">
         <classpath refid="classpath.rt" />
         <classpath>
             <pathelement location="${basedir}" />
             <pathelement location="${build.classes.dir}" />
         </classpath>
     </java>
 </target>

エラーは 1 行目でスローされます。

基本的に、私は呼び出し以外は何もしていません

最終的な KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();

Windows XP、Java6、および Ant.1.7 で実行しています。Drools-Rules の最新 (昨日の時点) のバージョン 5。

4

2 に答える 2

9

問題の鍵は、エラー リストの次の行です。「Caused by: java.lang.RuntimeException: The Eclipse JDT Core jar is not in the classpath」

この参照は、Eclipse Drools プラグインによってインストールされるライブラリ「core-3.4.2.v_883_R34x.jar」へのものです。

ライブラリに core-3.4.2.v_883_R34x.jar を追加すると、ランタイム例外は発生しません。

于 2010-08-04T14:00:15.450 に答える
2

drools-5.0-examples HelloWorld を試してから、Maven を使用してサンプル コードを試してみたところ、うまくいきました。次に、あなたが説明した特性を持つAntビルドファイルを作成し、あなたが行ったのとまったく同じ結果を得ました。

Maven バージョンには、さらに多くの依存ライブラリが含まれていることに気付きました。これらの依存関係を Maven から Ant バージョンの "lib" ディレクトリにコピーし、build.xml を更新してこれらを含めると、コードは正常に動作します。

<path id="classpath.rt">
  <pathelement location="${lib.dir}/antlr-runtime-3.1.1.jar" />
  <pathelement location="${lib.dir}/core-3.4.2.v_883_R34x.jar" />
  <pathelement location="${lib.dir}/drools-api-5.0.1.jar" />
  <pathelement location="${lib.dir}/drools-compiler-5.0.1.jar" />
  <pathelement location="${lib.dir}/drools-core-5.0.1.jar" />
  <pathelement location="${lib.dir}/drools-transformer-xstream-5.0.1.jar" />
  <pathelement location="${lib.dir}/janino-2.5.15.jar" />
  <pathelement location="${lib.dir}/joda-time-1.6.jar" />
  <pathelement location="${lib.dir}/mvel2-2.0.10.jar" />
  <pathelement location="${lib.dir}/xpp3_min-1.1.4c.jar" />
  <pathelement location="${lib.dir}/xstream-1.3.1.jar" />      
</path>
于 2010-04-28T13:48:19.957 に答える