行动是治愈恐惧的良药,而犹豫、拖延将不断滋养恐惧。

elasticsearch5.1.2版本java项目中连接client端报错问题请教?

Elasticsearch | 作者 eli0827 | 发布于2017年02月13日 | 阅读数:11412

使用的maven依赖如下:
<dependency>
         <groupId>org.elasticsearch.client</groupId>
         <artifactId>transport</artifactId>
         <version>5.1.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.7</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.7</version>
    </dependency>
  服务器端安装的是5.1.2版本的es
 测试代码如下:
public class Test {

    public static void main(String args) throws Exception {

        Settings settings = Settings.builder().put("cluster.name", "elasticsearch")
                  .put("client.transport.sniff", true).build();
        TransportClient client = new PreBuiltTransportClient(settings)
        .addTransportAddress(new               InetSocketTransportAddress(InetAddress.getByName("10.71.32.181"), 9200))
        .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("10.71.32.182"), 9201));
    }
}
报错情况:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/lucene/util/Accountable
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
    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)
    at org.elasticsearch.client.transport.TransportClient.newPluginService(TransportClient.java:89)
    at org.elasticsearch.client.transport.TransportClient.buildTemplate(TransportClient.java:119)
    at org.elasticsearch.client.transport.TransportClient.<init>(TransportClient.java:247)
    at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:125)
    at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:111)
    at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:101)
    at com.es.tet.Test.main(Test.java:26)
Caused by: java.lang.ClassNotFoundException: org.apache.lucene.util.Accountable
    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)
    ... 19 more
 有没有大神能遇到过这个问题,帮分析一下问题
已邀请:

kepmoving - 90后

赞同来自:

<dependency>
     <groupId>org.elasticsearch</groupId>
     <artifactId>elasticsearch</artifactId>
     <version>5.1.2</version>
</dependency>

要回复问题请先登录注册