2014-07-02 76 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,所以我建议切换到那个。

相关问题