我有一个项目在我试图使用c3p0的 JBoss 7 服务器上运行。JBoss 7 不支持像以前的版本那样只将 jar 转储到 /lib 文件夹中。据我了解,我需要使用新的模块系统。以下是我采取的步骤:
从这里下载了 c3p0 jar:http: //sourceforge.net/projects/c3p0/ ?source=dlp
将 3 个 jar 复制到我的 Eclipse 项目中并将它们添加到构建路径中(我相当确定这是正确完成的)。
在 JBOSS_HOME\modules\com\c3p0\main 创建了一个文件夹,我在那里添加了 3 个 jar,另外我创建了一个包含以下内容的文件“module.xml”:
<?xml version="1.0" encoding="UTF-8
<module xmlns="urn:jboss:module:1.0" name="com.c3p0">
<resources>
<resource-root path="c3p0-0.9.5-pre8.jar"/>
<resource-root path="c3p0-oracle-thin-extras-0.9.5-pre8.jar"/>
<resource-root path="mchange-commons-java-0.2.7.jar"/>
</resources>
</module>
我在我的 JBoss Standalone.xml 中添加了以下内容(sun.jdk 部分已经存在):
<subsystem xmlns="urn:jboss:domain:ee:1.0">
<global-modules>
<module name="sun.jdk" slot="main"/>
<module name="com.c3p0" slot="main"/>
</global-modules>
</subsystem>
运行服务器并访问使用 c3p0 jar 中的类的代码部分。收到以下错误消息(删节):
WARN [org.jboss.modules] (http-localhost-127.0.0.1-9091-2) Failed to define class com.mchange.v2.c3p0.ComboPooledDataSource in Module "com.c3p0:main" from local module loader @50908fa9 (roots: C:\jboss-as-web-7.0.2.Final\modules): java.lang.LinkageError: Failed to link com/mchange/v2/c3p0/ComboPooledDataSource (Module "com.c3p0:main" from local module loader @50908fa9 (roots: C:\jboss-as-web-7.0.2.Final\modules))
at org.jboss.modules.ModuleClassLoader.defineClass(ModuleClassLoader.java:401)
at org.jboss.modules.ModuleClassLoader.loadClassLocal(ModuleClassLoader.java:261)
at org.jboss.modules.ModuleClassLoader$1. loadClassLocal(ModuleClassLoader.java:76)
... LOTS MORE
Caused by: java.lang.NoClassDefFoundError: javax/naming/Referenceable
at java.lang.ClassLoader.defineClass1(Native Method) [:1.7.0_45]
at java.lang.ClassLoader.defineClass(Unknown Source) [:1.7.0_45]
at java.security.SecureClassLoader.defineClass(Unknown Source) [:1.7.0_45]
at org.jboss.modules.ModuleClassLoader.defineClass(ModuleClassLoader.java:397)
... 86 more
Caused by: java.lang.ClassNotFoundException: javax.naming.Referenceable from [Module "com.c3p0:main" from local module loader @50908fa9 (roots: C:\jboss-as-web-7.0.2.Final\modules)]
at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:191)
at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:361)
at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:333)
at org.jboss.modules.ConcurrentClassLoader.performLoadClass(ConcurrentClassLoader.java:310)
at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:103)
... 90 more
javax.ejb.EJBException: Unexpected Error
at org.jboss.as.ejb3.tx.CMTTxInterceptor.handleExceptionInOurTx(CMTTxInterceptor.java:157)
...
Caused by: java.lang.LinkageError: Failed to link com/mchange/v2/c3p0/ComboPooledDataSource (Module "com.c3p0:main" from local module loader @50908fa9 (roots: C:\jboss-as-web-7.0.2.Final\modules))
at org.jboss.modules.ModuleClassLoader.defineClass(ModuleClassLoader.java:401)
...
Caused by: java.lang.NoClassDefFoundError: javax/naming/Referenceable
at java.lang.ClassLoader.defineClass1(Native Method)
...
Caused by: java.lang.ClassNotFoundException: javax.naming.Referenceable from [Module "com.c3p0:main" from local module loader @50908fa9 (roots: C:\jboss-as-web-7.0.2.Final\modules)]
at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:191)
...
我究竟做错了什么?任何帮助深表感谢!
解决方案:
我的 module.xml 缺少依赖项。一个有效的方法如下:
<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.0" name="com.c3p0">
<resources>
<resource-root path="c3p0-0.9.5-pre8.jar"/>
<resource-root path="c3p0-oracle-thin-extras-0.9.5-pre8.jar"/>
<resource-root path="mchange-commons-java-0.2.7.jar"/>
</resources>
<dependencies>
<module name="javax.api"/>
<module name="javax.transaction.api"/>
<module name="org.hibernate"/>
</dependencies>
</module>