0

我在 GlassFish 2.1 中遇到了一个奇怪的问题 - 我是这个容器的初学者,我无法将其固定下来。

我有一个新安装的 GlassFish 2.1,其中定义了一个名为 testDerbyPool 的 JDBC 连接池。然后,我定义了一个名为 jdbc/testDerbyPool 的资源,指向该池。资源类型是 javax.sql.DataSource,我可以成功 ping 池。

然后,我在带有此声明的 webapp 中有一个类:

@Resource(name="jdbc/testDerbyPool")
private javax.sql.DataSource source;

我的 web.xml 中的这个声明:

  <resource-ref>
    <res-ref-name>jdbc/testDerbyPool</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
  </resource-ref>

当我尝试部署应用程序时,我收到此错误:

[#|2009-09-09T21:40:47.582+0100|SEVERE|sun-appserver9.1|javax.enterprise.system.container.web|_ThreadID=24;_ThreadName=Thread-32;_RequestID=1ca4ab80-ae39-4920-be18-f535b025bb51;|WebModule[/cptest1]PWC1275: Exception sending context initialized event to listener instance of class com.sun.faces.config.ConfigureListener

和一个巨大的堆栈跟踪,开始:

java.lang.NoClassDefFoundError: LDataSource;
at java.lang.Class.getDeclaredFields0(Native Method)
at java.lang.Class.privateGetDeclaredFields(Class.java:2291)

根本原因:

Caused by: java.lang.ClassNotFoundException: DataSource
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1498)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)

我不明白如何“找不到”数据源!有任何想法吗?

4

1 回答 1

2

下次我在问完这个问题后回去时,我注意到 Eclipse 中的一个构建错误,不知何故在标记为“未绑定”的路径中获得了一个额外的 JRE。环顾我的系统,我在启动 Eclipse 和进行构建/部署之间自动获得了 JVM 点发布更新。

无论如何,删除它,再次尝试,工作。

因此,如果您看到此问题,请检查构建错误和构建路径问题。

于 2009-09-09T20:58:47.963 回答