Я разрабатываю настольное приложение с Datanucleus и JDO для встроенной базы данных H2. Все отлично работает, когда я запускаю его из Eclipse, но перестает работать, когда я пытаюсь сделать из него исполняемый jar. Я получаю следующую ошибку:
org.datanucleus.exceptions.NucleusUserException:Процесс сохранения был указан для использования ClassLoaderResolver с именем «jdo», но это не было обнаружено механизмом подключаемого модуля DataNucleus. Пожалуйста, проверьте свой CLASSPATH и спецификацию плагина.
Конечно, это показывает, что я что-то неправильно настроил -что я упускаю? Если бы я пропустил что-то большое, это бы вообще не сработало, поэтому я предполагаю, что это ошибочный исполняемый файл jar. Я видел эту ошибку в других приложениях, таких как JPOX, где она была исправлена, но без какого-либо решения.
Полная трассировка стека ошибок:
Exception in thread "main" javax.jdo.JDOFatalInternalException: Unexpected exception caught.
at javax.jdo.JDOHelper.invokeGetPersistenceManagerFactoryOnImplementation(JDOHelper.java:1193)
at javax.jdo.JDOHelper.getPersistenceManagerFactory(JDOHelper.java:808)
at javax.jdo.JDOHelper.getPersistenceManagerFactory(JDOHelper.java:701)
at db.PersistenceManagerFilter.init(PersistenceManagerFilter.java:44)
at Main.main(Main.java:26)
NestedThrowablesStackTrace:
java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at javax.jdo.JDOHelper$16.run(JDOHelper.java:1965)
at java.security.AccessController.doPrivileged(Native Method)
at javax.jdo.JDOHelper.invoke(JDOHelper.java:1960)
at javax.jdo.JDOHelper.invokeGetPersistenceManagerFactoryOnImplementation(JDOHelper.java:1166)
at javax.jdo.JDOHelper.getPersistenceManagerFactory(JDOHelper.java:808)
at javax.jdo.JDOHelper.getPersistenceManagerFactory(JDOHelper.java:701)
at db.PersistenceManagerFilter.init(PersistenceManagerFilter.java:44)
at Main.main(Main.java:26)
Caused by: org.datanucleus.exceptions.NucleusUserException: Persistence process has been specified to use a ClassLoaderResolver of name "jdo" yet this has not been found by the DataNucleus plugin mechanism. Please check your CLASSPATH and plugin specification.
at org.datanucleus.NucleusContext.(NucleusContext.java:233)
at org.datanucleus.NucleusContext.(NucleusContext.java:196)
at org.datanucleus.NucleusContext.(NucleusContext.java:174)
at org.datanucleus.api.jdo.JDOPersistenceManagerFactory.(JDOPersistenceManagerFactory.java:364)
at org.datanucleus.api.jdo.JDOPersistenceManagerFactory.createPersistenceManagerFactory(JDOPersistenceManagerFactory.java:294)
at org.datanucleus.api.jdo.JDOPersistenceManagerFactory.getPersistenceManagerFactory(JDOPersistenceManagerFactory.java:195)
... 12 more
Строка, на которую он указывает, является методом инициализации PersistenceManagerFilter:
pmf = JDOHelper.getPersistenceManagerFactory(getProperties());
Файл свойств выглядит так:
javax.jdo.PersistenceManagerFactoryClass=org.datanucleus.api.jdo.JDOPersistenceManagerFactory
datanucleus.ConnectionDriverName=org.h2.Driver
datanucleus.ConnectionURL=jdbc:h2:datanucleus
datanucleus.ConnectionUserName=sa
datanucleus.ConnectionPassword=
У меня есть все зависимости от maven, с целью развертывания с зависимостями. Зависимости указаны на странице datanucleus http://www.datanucleus.org/products/datanucleus/jdo/maven.html
. Есть идеи?