2016-03-30 1 views
0

Я обновил JBoss до WildFly 9 с помощью Liferay и с Java 7 до Java 8. Я также обновил драйвер postgresql jdbc до версии 9.4-1207.Не удалось запустить службу jboss.persistenceunit: NullPointerException postgresql.jdbc.TypeInfoCache.getSQLType

С тех пор я не могу развернуть мое приложение, как он выдает следующее сообщение об ошибке:

2016-03-30 10:02:07,404 INFO [org.jboss.as.jpa] (ServerService Thread Pool -- 201) WFLYJPA0010: Starting Persistence Unit (phase 2 of 2) Service 'TestEJBsWithArquillian.war#at.testapplication.jpa' 
2016-03-30 10:02:08,544 ERROR [org.jboss.msc.service.fail] (ServerService Thread Pool -- 201) MSC000001: Failed to start service jboss.persistenceunit."TestEJBsWithArquillian.war#at.testapplication.jpa": org.jboss.msc.service.StartException in service jboss.persistenceunit."TestEJBsWithArquillian.war#at.testapplication.jpa": java.lang.NullPointerException 
    at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:172) 
    at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:117) 
    at org.wildfly.security.manager.WildFlySecurityManager.doChecked(WildFlySecurityManager.java:665) 
    at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1.run(PersistenceUnitServiceImpl.java:182) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
    at org.jboss.threads.JBossThread.run(JBossThread.java:320) 
Caused by: java.lang.NullPointerException 
    at org.postgresql.jdbc.TypeInfoCache.getSQLType(TypeInfoCache.java:185) 
    at org.postgresql.jdbc.TypeInfoCache.getSQLType(TypeInfoCache.java:180) 
    at org.postgresql.jdbc.TypeInfoCache.requiresQuoting(TypeInfoCache.java:823) 
    at org.postgresql.jdbc.PgDatabaseMetaData.getTypeInfo(PgDatabaseMetaData.java:2952) 
    at org.hibernate.engine.jdbc.spi.TypeInfo.extractTypeInfo(TypeInfo.java:101) 
    at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:163) 
    at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:111) 
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:234) 
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:206) 
    at org.hibernate.cfg.Configuration.buildTypeRegistrations(Configuration.java:1887) 
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1845) 
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:857) 
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:850) 
    at org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.withTccl(ClassLoaderServiceImpl.java:425) 
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:849) 
    at org.jboss.as.jpa.hibernate4.TwoPhaseBootstrapImpl.build(TwoPhaseBootstrapImpl.java:44) 
    at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:154) 
    ... 7 more 

У меня есть следующий persistence.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" 
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
      xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> 
    <persistence-unit name="at.testapplication.jpa" transaction-type="JTA"> 
     <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider> 
     <jta-data-source>jdbc/databasePool</jta-data-source> 
     <exclude-unlisted-classes>false</exclude-unlisted-classes> 
     <shared-cache-mode>ALL</shared-cache-mode> 
     <validation-mode>AUTO</validation-mode> 
     <properties> 
      <property name="hibernate.hbm2ddl.auto" value="validate"/> 
      <property name="hibernate.show_sql" value="false"/> 
      <property name="hibernate.jdbc.batch_size" value="10"/> 
      <property name="hibernate.jdbc.fetch_size" value="10"/> 
      <property name="hibernate.dialect" value="${testapplication.database.dialect}"/> 
      <property name="hibernate.transaction.manager_lookup_class" 
         value="org.hibernate.transaction.JBossTransactionManagerLookup"/> 
      <property name="hibernate.transaction.jta.platform" 
         value="org.hibernate.service.jta.platform.internal.JBossAppServerJtaPlatform" /> 
      <property name="hibernate.search.default.directory_provider" value="filesystem"/> 
      <property name="hibernate.search.default.indexBase" value="${liferay.home}/data/lucene"/> 
      <property name="hibernate.cache.use_second_level_cache" value="false"/> 
      <property name="hibernate.cache.use_query_cache" value="false"/> 
     </properties> 
    </persistence-unit> 
</persistence> 

Это standalone.xml (I пингуется источник данных из wildfly интерфейса администратора):

<subsystem xmlns="urn:jboss:domain:datasources:3.0"> 
      <datasources> 
       <datasource jta="true" jndi-name="java:/jdbc/databasePool" pool-name="databasePool" enabled="true" use-java-context="true" use-ccm="true"> 
        <connection-url>jdbc:postgresql://localhost/db</connection-url> 
        <driver>postgresql</driver> 
        <security> 
         <user-name>admin</user-name> 
         <password>admin</password> 
        </security> 
        <validation> 
         <valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLValidConnectionChecker"/> 
         <exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLExceptionSorter"/> 
        </validation> 
       </datasource> 
       <drivers> 
        <driver name="postgresql" module="org.postgresql"> 
         <datasource-class>org.postgresql.ds.PGConnectionPolDataSource</datasource-class> 
        </driver> 
       </drivers> 
      </datasources> 
     </subsystem> 

Я могу пинг мой databasePool из Интерфейс администратора Wildfly. Кто-нибудь есть идея, что может вызвать это? Похоже, что драйвер JDBC бросает исключение NullPointerException. Я также пробовал другие версии драйвера JDBC, но он по-прежнему бросает ту же ошибку.

ответ

2

Ну, оказывается, мои метаданные базы данных были повреждены. после восстановления базы данных у коллеги приложение развернуто просто отлично.

 Смежные вопросы

  • Нет связанных вопросов^_^