java.lang.ClassNotFoundException: источник данных в Glassfish - PullRequest
0 голосов
/ 10 сентября 2009

У меня странная проблема в GlassFish 2.1 - я новичок в этом контейнере, и у меня возникают проблемы с его закреплением.

У меня установлена ​​новая версия GlassFish 2.1 с определенным пулом соединений JDBC, называемым testDerbyPool. Затем я определил ресурс под названием jdbc / testDerbyPool, указывающий на этот пул. Тип ресурса - javax.sql.DataSource, и я могу успешно пропинговать пул.

У меня есть один класс в веб-приложении с этим объявлением:

@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)

Я не понимаю, как DataSource может быть «не найден»! Есть идеи?

1 Ответ

2 голосов
/ 10 сентября 2009

В следующий раз, когда я вернулся после того, как задал вопрос, я заметил ошибку сборки в Eclipse, каким-то образом получил дополнительный JRE по пути, помеченному как «unbound». Осматривая свою систему, я автоматически получал обновление выпуска JVM между запуском Eclipse и выполнением сборки / развертывания.

Во всяком случае, удалил его, попробовал еще раз, работал.

Так что проверьте ошибки сборки и проблемы с путями сборки, если вы видите эту проблему.

...