Elasticsearch在Tomcat 7上导致带有javax / servlet / FilterConfig的java.lang.LinkageError

时间:2014-05-02 07:16:41

标签: java spring tomcat elasticsearch

我使用Elasticsearch 1.1.1,java客户端和服务器版本是相同的。单元测试都运行良好。当我启动tomcat服务器时,它有:

java.lang.LinkageError: loader constraint violation: loader (instance of org/apache/catalina/loader/WebappClassLoader) previously initiated loading for a different type with name "javax/servlet/FilterConfig"

在此错误之前,有很多以下内容:

2014-05-02 15:07:03,954 DEBUG o.e.plugins [localhost-startStop-1] [Corsair] [D:\eclipse-indigo\plugins\org.python.pydev.jython_2.7.0.2012080220\_site] directory does not exist.

很多并且使用不同的文件夹

如果我删除使用elasticsearch的代码并将依赖关系保存在pom.xml中,则服务器启动正常。 WEB-INF/lib和我应用的类路径没有servlet-api.jar,只有TOMCAT_HOME/lib

我设置es客户端的部分如下:

if (this.client == null) {

    this.client = new TransportClient(ImmutableSettings.settingsBuilder().
            put("cluster.name", this.cluster).build());

    final String[] addresses = this.hosts.split(",");

    for (final String address : addresses) {

        final String trimmed = address.trim();
        final String[] tuple = trimmed.split(":");
        this.client.addTransportAddress(
                new InetSocketTransportAddress(tuple[0].trim(), Integer.valueOf(tuple[1].trim())));

    }

}

相同的代码用于单元测试,它通过了所有测试。

非常感谢任何指针。

这似乎是相关的,但尚未提供适当的解决方案。

Linkage error when using Elasticsearch client in Spring WebApp

仅供参考,我也使用Spring& Spring MVC 4.2.5.RELEASE,Tomcat 7.0.40版本

更新:

感谢这个链接http://lexxweb.co.uk/blog/?p=66,事实证明它是eclipse插件之一,它加载了另一个版本的servlet-api,导致了我已经获得的LinkageError。

1 个答案:

答案 0 :(得分:4)

感谢这个链接http://lexxweb.co.uk/blog/?p=66,事实证明它是eclipse插件之一,它加载了另一个版本的servlet-api,导致我得到的LinkageError。删除插件后,现在一切都很好