2012-05-06 25 views
17

Tôi không thể tìm ra lý do tại sao tôi nhận được lỗi này. Tôi đã cố gắng dọn dẹp các libs thừa và vv.java.lang.IncompatibleClassChangeError: Triển khai lớp Mongo

tôi nhận được báo lỗi khi tôi cố gắng để làm:

mongo = new Mongo(host, port); 

Điều buồn cười là tôi có thể chạy bất kỳ kiểm tra đơn vị tôi làm từ IDE (IntelliJ), nhưng khi tôi cố gắng chạy nó thông qua Tomcat tôi có được điều này:

Caused by: org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com. 
    sfatandrei.db.MongoManager]: Constructor threw exception; nested exception is java.lang.IncompatibleCla 
    ssChangeError: Implementing class 
     at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:162) 
     at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInst 
    antiationStrategy.java:110) 
     at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(Constructo 
    rResolver.java:280) 
     ... 82 more 
    Caused by: java.lang.IncompatibleClassChangeError: Implementing class 
     at java.lang.ClassLoader.defineClass1(Native Method) 
     at java.lang.ClassLoader.defineClass(ClassLoader.java:791) 
     at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) 
     at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2889) 
     at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1170) 
     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678) 
     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1556) 
     at java.lang.ClassLoader.defineClass1(Native Method) 
     at java.lang.ClassLoader.defineClass(ClassLoader.java:791) 
     at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) 
     at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2889) 
     at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1170) 
     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678) 
     at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1556) 
     at com.mongodb.MongoOptions.reset(MongoOptions.java:47) 
     at com.mongodb.MongoOptions.<init>(MongoOptions.java:29) 
     at com.mongodb.Mongo.<init>(Mongo.java:148) 
     at com.mongodb.Mongo.<init>(Mongo.java:137) 
     at com.sfatandrei.db.MongoManager.<init>(MongoManager.java:28) 
     at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
     at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 
     at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl. 
    java:45) 
     at java.lang.reflect.Constructor.newInstance(Constructor.java:525) 
     at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:147) 
     ... 84 more 

mvn dependency:tree -Dverbose

[INFO] 
[INFO] --- maven-dependency-plugin:2.1:tree (default-cli) @ mongodb-performance-test --- 
[INFO] com.sfatandrei:mongodb-performance-test:war:1.0 
[INFO] +- junit:junit:jar:4.8.2:test 
[INFO] +- org.springframework:spring-core:jar:3.1.1.RELEASE:compile 
[INFO] | +- org.springframework:spring-asm:jar:3.1.1.RELEASE:compile 
[INFO] | \- (commons-logging:commons-logging:jar:1.1.1:compile - omitted for duplicate) 
[INFO] +- org.springframework:spring-beans:jar:3.1.1.RELEASE:compile 
[INFO] | \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] +- org.springframework:spring-context:jar:3.1.1.RELEASE:compile 
[INFO] | +- org.springframework:spring-aop:jar:3.1.1.RELEASE:compile 
[INFO] | | +- (aopalliance:aopalliance:jar:1.0:compile - omitted for duplicate) 
[INFO] | | +- (org.springframework:spring-asm:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | | \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- org.springframework:spring-expression:jar:3.1.1.RELEASE:compile 
[INFO] | | \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | \- (org.springframework:spring-asm:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] +- org.springframework:spring-jdbc:jar:3.1.1.RELEASE:compile 
[INFO] | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | \- org.springframework:spring-tx:jar:3.1.1.RELEASE:compile 
[INFO] |  +- (aopalliance:aopalliance:jar:1.0:compile - omitted for duplicate) 
[INFO] |  +- (org.springframework:spring-aop:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  +- (org.springframework:spring-context:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] |  \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] +- org.springframework:spring-web:jar:3.1.1.RELEASE:compile 
[INFO] | +- aopalliance:aopalliance:jar:1.0:compile 
[INFO] | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-context:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] +- org.springframework:spring-webmvc:jar:3.1.1.RELEASE:compile 
[INFO] | +- (org.springframework:spring-asm:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-context:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- org.springframework:spring-context-support:jar:3.1.1.RELEASE:compile 
[INFO] | | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | | +- (org.springframework:spring-context:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | | \- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-core:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-expression:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | \- (org.springframework:spring-web:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] +- org.springframework.data:spring-data-mongodb:jar:1.0.0.RELEASE:compile 
[INFO] | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- (org.springframework:spring-expression:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | +- org.springframework.data:spring-data-commons-core:jar:1.2.0.RELEASE:compile 
[INFO] | | +- (org.springframework:spring-beans:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | | \- (org.springframework:spring-tx:jar:3.1.1.RELEASE:compile - omitted for duplicate) 
[INFO] | \- org.mongodb:mongo-java-driver:jar:2.7.1:compile 
[INFO] +- log4j:log4j:jar:1.2.16:compile 
[INFO] +- org.springframework:spring-test:jar:3.1.1.RELEASE:compile 
[INFO] +- commons-logging:commons-logging:jar:1.1.1:compile 
[INFO] +- javax.servlet:servlet-api:jar:2.5:provided 
[INFO] +- org.mongodb:bson:jar:2.3:compile 
[INFO] \- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.6:compile 
[INFO] \- org.codehaus.jackson:jackson-core-asl:jar:1.9.6:compile 

tôi đang sử dụng jdk 7, tomcat 7.0. 27, maven 3.0.3.

+1

Nói chung lỗi là do biên dịch với một bộ tệp JAR và chạy với một tập hợp khác. Nó có thể là lớp học của bạn hoặc một trong các lớp học trong một trong các JAR mà bạn sử dụng. Thật không may, nó không xuất hiện để cho chúng tôi biết lớp nào đã gặp lỗi. –

+0

@HotLicks, trên thực tế, nó cho biết lớp nào đã xảy ra lỗi: 'at com.mongodb.MongoOptions.reset (MongoOptions.java:47) ' – sfat

+1

Không, đó là nơi xảy ra lỗi. Nhưng lỗi xảy ra trên lớp đang được tải, bất kể đó là gì. Nếu bạn có thể kiểm tra mã tại thời điểm đó, bạn có thể giải mã lớp nào đang được tải. –

Trả lời

19

Điều đó có vẻ như là lỗi của cấp mã byte. Có lẽ bạn có hai phiên bản của cùng một thư viện trong máy chủ tomcat của bạn.

Xem: What causes java.lang.IncompatibleClassChangeError?

+2

có vẻ như 'mongo-java-driver' có bên trong một lớp có sử dụng org.bson và tôi tự thêm vào sự phụ thuộc của 'bson' và điều đó đã gây cản trở – sfat

1

Nếu bạn nhận vấn đề này dưới JBoss, nó rất có thể do thực tế là JBoss bó thực hiện RESTeasy nghỉ ngơi càng mặc định. Nếu bạn đóng gói thư viện REST của riêng bạn vào tệp EAR/WAR, bạn cần vô hiệu hóa RESTeasy mặc định cho thư viện được triển khai của bạn để làm việc.

Các vấn đề liên quan