0

Java Playをデプロイしようとしています!2アプリケーション。play clean distデプロイされたアプリケーションを含むzipファイルを作成するBambooサーバーが実行されています。次に、Bambooはファイルを解凍し、シンボリック(currentという名前)リンクをこの新しいフォルダーに変更します。

次に、手動で(今すぐ)startスクリプトを実行したいのですが、java.lang.IncompatibleClassChangeError例外がスローされます:

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)

このエラーに関する投稿をたくさん読みましたが、今のところ問題を解決できるものはありません。次のように、フォルダを別の場所にコピーしようとしました。

root # cp -r /home/webserver/current /root/webserver-current
root # cd /root/webserver-current
root # ./start

そしてここでは、例外の代わりに、私のアプリケーションが機能しています!:-O私の結論は、/homeパーティションでは機能しないということですが、信じられません!それを機能させるためのアイデアや解決策はありますか?

よろしく、サミュエル。

4

2 に答える 2

0

アプリケーション全体をクリーンアップしてビルドする必要があります。クラスを再コンパイルせずに、それに依存する他のクラスに影響を与える何らかの方法でクラスを変更しました。

于 2012-12-10T08:57:51.060 に答える
0

依存関係の問題でした。ejb3-persistence-1.0.2.GAとの両方hibernate-jpa-2.0-apiが lib ディレクトリにあり、互換性がありません! (JPA 1.0 および JPA 2.0) ejb3-persistence-1.0.2.GAMaven ファイルと lib ディレクトリから削除したところ、動作しました。:)

于 2012-12-10T10:45:54.753 に答える