2014-07-02 118 views
0

我構建了一個DAL jar庫,它使用HikariCP作爲連接提供者。這個jar然後被包含(作爲一個Maven依賴)在一個web應用程序中。HikariConnectionProvider部署到JBoss應用服務器7.1時發生ClassNotFoundException

我將此Web應用程序測試到Wildfly 8.0.0應用程序服務器上,並且所有工作均如預期:部署過程無任何問題,我可以使用Web應用程序訪問數據庫。

當我運行相同的 Web應用程序到JBoss應用程序服務器7.1上時,問題就出現了。事實上,在部署過程以下情況例外結束堆棧

http://pastebin.com/qQh5EW1N

這裏是在DAL

<?xml version="1.0" encoding="UTF-8"?> 
<persistence 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" 
      version="2.0"> 

    <persistence-unit name="DALPersistenceUnit" transaction-type="JTA"> 

     <provider>org.hibernate.ejb.HibernatePersistence</provider> 

     <shared-cache-mode>NONE</shared-cache-mode> 

     <properties> 
      <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/> 
      <property name="hibernate.connection.provider_class" value="com.zaxxer.hikari.hibernate.HikariConnectionProvider"/> 
      <property name="hibernate.hikari.maximumPoolSize" value="100"/> 
      <property name="hibernate.hikari.minimumIdle" value="20"/> 
      <property name="hibernate.hikari.idleTimeout" value="30000"/> 
      <property name="hibernate.hikari.dataSourceClassName" value="com.mysql.jdbc.jdbc2.optional.MysqlDataSource"/> 
      <property name="hibernate.hikari.dataSource.url" value="jdbc:mysql://URL:3306/DB"/> 
      <property name="hibernate.hikari.dataSource.user" value="user"/> 
      <property name="hibernate.hikari.dataSource.password" value="pwd"/> 

      <property name="hibernate.archive.autodetection" value="class" /> 

     </properties> 
    </persistence-unit> 
</persistence> 

這裏confgured的persistence.xml是DAL的pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 

    <groupId>my.dal</groupId> 
    <artifactId>dal</artifactId> 
    <version>0.0.4-SNAPSHOT</version> 
    <packaging>jar</packaging> 

    <properties> 
     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
     <java.version>1.7</java.version> 
    </properties> 

    <dependencies> 

     <dependency> 
      <groupId>com.mysema.querydsl</groupId> 
      <artifactId>querydsl-core</artifactId> 
      <version>3.3.2</version> 
     </dependency> 
     <dependency> 
      <groupId>com.mysema.querydsl</groupId> 
      <artifactId>querydsl-apt</artifactId> 
      <version>3.3.2</version> 
     </dependency> 
     <dependency> 
      <groupId>com.mysema.querydsl</groupId> 
      <artifactId>querydsl-jpa</artifactId> 
      <version>3.3.2</version> 
     </dependency>  
     <dependency> 
      <groupId>log4j</groupId> 
      <artifactId>log4j</artifactId> 
      <version>1.2.16</version> 
     </dependency> 
     <dependency> 
      <groupId>org.jglue.cdi-unit</groupId> 
      <artifactId>cdi-unit</artifactId> 
      <version>3.0.1</version> 
      <scope>test</scope> 
     </dependency>  
     <dependency> 
      <groupId>junit</groupId> 
      <artifactId>junit</artifactId> 
      <version>4.11</version> 
     </dependency>  
     <dependency> 
      <groupId>javax</groupId> 
      <artifactId>javaee-api</artifactId> 
      <version>6.0</version> 
     </dependency> 
     <dependency> 
      <groupId>org.hibernate</groupId> 
      <artifactId>hibernate-core</artifactId> 
      <version>4.3.5.Final</version> 
     </dependency> 
     <dependency> 
      <groupId>org.hibernate.common</groupId> 
      <artifactId>hibernate-commons-annotations</artifactId> 
      <version>4.0.4.Final</version> 
     </dependency> 

     <dependency> 
      <groupId>javax.enterprise</groupId> 
      <artifactId>cdi-api</artifactId> 
      <version>1.1</version> 
     </dependency> 
     <dependency> 
      <groupId>org.hibernate.javax.persistence</groupId> 
      <artifactId>hibernate-jpa-2.1-api</artifactId> 
      <version>1.0.0.Final</version> 
     </dependency> 
     <dependency> 
      <groupId>org.hibernate</groupId> 
      <artifactId>hibernate-entitymanager</artifactId> 
      <version>4.3.5.Final</version> 
     </dependency> 
     <dependency> 
      <groupId>mysql</groupId> 
      <artifactId>mysql-connector-java</artifactId> 
      <version>5.1.30</version> 
     </dependency>  
     <dependency> 
      <groupId>com.zaxxer</groupId> 
      <artifactId>HikariCP</artifactId> 
      <version>1.4.0</version> 
      <scope>compile</scope> 
     </dependency> 
    </dependencies> 

    <build> 
     <finalName>DAL</finalName> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <version>3.1</version> 
       <configuration> 
        <source>${java.version}</source> 
        <target>${java.version}</target> 
       </configuration> 
      </plugin> 

      <plugin> 
       <groupId>com.mysema.maven</groupId> 
       <artifactId>apt-maven-plugin</artifactId> 
       <version>1.0.9</version> 
       <executions> 
       <execution> 
        <goals> 
        <goal>process</goal> 
        </goals> 
        <configuration> 
        <outputDirectory>target/generated-sources/java</outputDirectory> 
        <processor>com.mysema.query.apt.jpa.JPAAnnotationProcessor</processor> 
        </configuration> 
       </execution> 
       </executions> 
      </plugin> 

     </plugins> 
    </build> 

</project> 

你認爲這個問題可能是什麼?這是一個已知的HikariCP問題嗎? JBoss AS 7.1支持HikariCP嗎?

謝謝 最好的問候

朱利奧

+0

如果你能找到'HikariCP.jar',你可以看看你的jboss的classpath嗎? – Jens

+0

嗨@Jens。我提取了web應用程序的.war文件,並在WEB-INF/lib文件夾中找到了HicariCP-1.4.0jar庫 – gvdm

+0

HicariCP-1.4.0.jar中缺少該類(缺少的點是副本/粘貼錯誤? – Jens

回答

1

HikariCP無法加載,因爲該類org.hibernate.engine.jdbc.connections.spi.ConnectionProvider找不到,至少根據堆棧跟蹤。我會驗證Hibernate是正確的版本(與Wildfly中使用的版本相同)。另外,請注意Hibernate現在包含他們自己的HikariConnectionProvider,所以我建議切換到那個。

相關問題