特定情况下会出现java.lang.CompatibleClassChangeError
我正在尝试部署一个Java游戏!2.申请。My Bamboo服务器正在运行特定情况下会出现java.lang.CompatibleClassChangeError,java,playframework,Java,Playframework,我正在尝试部署一个Java游戏!2.申请。My Bamboo服务器正在运行play clean dist,这将生成一个包含已部署应用程序的zip文件。然后解压缩该文件,并将一个符号(名为current)链接更改为此新文件夹 然后,我想手动(现在)运行start脚本,但引发了java.lang.CompatibleClassChangeError异常: root # pwd /home/webserver/current/ root # ./start Play server process ID
play clean dist
,这将生成一个包含已部署应用程序的zip文件。然后解压缩该文件,并将一个符号(名为current)链接更改为此新文件夹
然后,我想手动(现在)运行start
脚本,但引发了java.lang.CompatibleClassChangeError
异常:
root # pwd
/home/webserver/current/
root # ./start
Play server process ID is 9795
[info] play - datasource [jdbc:mysql://XXX/XXX] bound to JNDI as DefaultDS
[debug] c.j.b.BoneCPDataSource - JDBC URL = jdbc:mysql://XXX/XXX, Username = lmc, artitions = 3, max (per partition) = 5, min (per partition) = 2, helper threads = 3, idle max ge = 10 min, idle test period = 5 min
[info] play - database [default] connected at jdbc:mysql://XXX/XXX
Oops, cannot start the server.
java.lang.IncompatibleClassChangeError: Implementing class
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:634)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:277)
at java.net.URLClassLoader.access$000(URLClassLoader.java:73)
at java.net.URLClassLoader$1.run(URLClassLoader.java:212)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:905)
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:890)
at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:57)
at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:52)
at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:34)
at play.db.jpa.JPAPlugin.onStart(JPAPlugin.java:35)
at play.api.Play$$anonfun$start$1.apply(Play.scala:60)
at play.api.Play$$anonfun$start$1.apply(Play.scala:60)
at scala.collection.LinearSeqOptimized$class.foreach(LinearSeqOptimized.scala:59)
at scala.collection.immutable.List.foreach(List.scala:45)
at play.api.Play$.start(Play.scala:60)
at play.core.StaticApplication.<init>(ApplicationProvider.scala:51)
at play.core.server.NettyServer$.createServer(NettyServer.scala:133)
at play.core.server.NettyServer$$anonfun$main$5.apply(NettyServer.scala:162)
at play.core.server.NettyServer$$anonfun$main$5.apply(NettyServer.scala:161)
at scala.Option.map(Option.scala:133)
at play.core.server.NettyServer$.main(NettyServer.scala:161)
at play.core.server.NettyServer.main(NettyServer.scala)
在这里,我的应用程序正在运行,而不是异常情况!:-O
我的结论是它在/home
分区上不起作用,但我不敢相信!
你有什么想法或解决办法让它工作吗
问候,,
Samuel。您需要清理并构建整个应用程序。您以某种方式更改了一个类,该类会影响依赖它的其他类,而不会重新编译这些类。这是一个依赖性问题。
ejb3-persistence-1.0.2.GA
和hibernate-jpa-2.0-api
都在lib目录中,它们不兼容!(JPA 1.0和JPA 2.0)
我从我的Maven文件和lib目录中删除了
ejb3-persistence-1.0.2.GA
,它可以正常工作 谢谢你的回答。我正在运行“cleandist”来重新编译我的整个应用程序。同样,正如我在文章最后所说的,同一个包正在另一个分区上工作…@SamuelROZE没有改变我的答案。如果你得到那个例外,那就是原因。查找错误的“干净构建”、错误的部署等。
root # cp -r /home/webserver/current /root/webserver-current
root # cd /root/webserver-current
root # ./start