2017-01-13 22 views
2

我想通過使用java api編寫一個基本程序來熟悉elasticsearch。我一直在研究一個答案,但我不確定是否正在執行我發現不正確的解決方案,或者只是沒有看到真正的問題。彈性搜索java.lang.NoClassDefFoundError:org/elasticsearch/transport/Netty3Plugin

我使用elasticsearch-5.1.1並下載了最新的傳輸版本(5.1.1)。我也在項目結構中添加了兩個(包括隨elasticsearch下載一起提供的所有jar文件)。

在此先感謝!

運行我的測試文件時,出現以下錯誤。

錯誤:

java.lang.NoClassDefFoundError: org/elasticsearch/transport/Netty3Plugin 

at org.elasticsearch.transport.client.PreBuiltTransportClient.<clinit>(PreBuiltTransportClient.java:54) 
at DictionarySearch.ElasticSearch.<init>(ElasticSearch.java:41) 
at test.TestIndexSearcher.verifyElasticSearch(TestIndexSearcher.java:64) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:497) 
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
at org.junit.runner.JUnitCore.run(JUnitCore.java:137) 
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:117) 
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:42) 
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:262) 
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:84) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:497) 
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147) 
Caused by: java.lang.ClassNotFoundException: org.elasticsearch.transport.Netty3Plugin 
at java.net.URLClassLoader.findClass(URLClassLoader.java:381) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:424) 
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:357) 
... 30 more 

我已經添加了以下依存關係到我的pom.xml文件和安裝xpack下面給出directions。我的pom.xml與我的log4j2.xml文件一起位於src/lib中。

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
<modelVersion>4.0.0</modelVersion> 
<groupId>org.elasticsearch.client</groupId> 
<artifactId>transport</artifactId> 
<version>5.1.1</version> 
<repositories> 
    <repository> 
     <id>elasticsearch-releases</id> 
     <url>https://maven.elasticsearch.org/releases</url> 
     <releases> 
      <enabled>true</enabled> 
     </releases> 
     <snapshots> 
      <enabled>false</enabled> 
     </snapshots> 
    </repository> 
</repositories> 

<dependencies> 
    <dependency> 
     <groupId>org.elasticsearch.client</groupId> 
     <artifactId>x-pack-transport</artifactId> 
     <version>5.1.1</version> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch</groupId> 
     <artifactId>elasticsearch-transport-wares</artifactId> 
     <version>2.7.0</version> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch</groupId> 
     <artifactId>elasticsearch</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch.plugin</groupId> 
     <artifactId>transport-netty3-client</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.apache.logging.log4j</groupId> 
     <artifactId>log4j-api</artifactId> 
     <version>2.7</version> 
     <scope>test</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.apache.logging.log4j</groupId> 
     <artifactId>log4j-core</artifactId> 
     <version>2.7</version> 
     <scope>test</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch.plugin</groupId> 
     <artifactId>transport-netty4-client</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch.plugin</groupId> 
     <artifactId>reindex-client</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch.plugin</groupId> 
     <artifactId>lang-mustache-client</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.elasticsearch.plugin</groupId> 
     <artifactId>percolator-client</artifactId> 
     <version>5.1.1</version> 
     <scope>compile</scope> 
    </dependency> 
</dependencies> 
<inceptionYear>2009</inceptionYear> 
<licenses> 
    <license> 
     <name>The Apache Software License, Version 2.0</name> 
     <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url> 
     <distribution>repo</distribution> 
    </license> 
</licenses> 
<developers> 
    <developer> 
     <name>Elastic</name> 
     <url>http://www.elastic.co</url> 
    </developer> 
</developers> 
<name>transport</name> 
<description>Elasticsearch subproject :client:transport</description> 
<url>https://github.com/elastic/elasticsearch</url> 
<scm> 
    <url>[email protected]:elastic/elasticsearch.git</url> 
</scm> 

回答

0

原來我沒有Maven的正確設置在我的IDE。我正在使用IntelliJ。在IntelliJ中,您必須指出您在設置項目時使用了maven。

爲了解決我的問題,我在maven中創建了一個新項目並移動了我的java類文件。一個pom.xml文件是爲我自動創建的。我只能將所需的依賴添加到pom.xml文件中,並使用Maven自動將它們導入到我的項目中。

如果您遇到此問題,我會建議仔細檢查您的IDE是否按照您認爲的方式使用Maven。