使用wildfly 10.1.0.Final执行“mvn wildfly:deploy”时出现问题,hibernate ogm 5.0.10.Final和Cassandra 3.0.9

时间:2017-02-28 22:46:12

标签: maven wildfly-10 cassandra-3.0 hibernate-ogm

伙计们,我在做“mvn wildfly:deploy”时遇到了麻烦。 这是错误代码:

  

[错误]无法在项目aigateway上执行目标org.wildfly.plugins:wildfly-maven-plugin:1.1.0.Final:deploy(default-cli):无法执行目标部署:{“WFLYCTL0062:复合操作失败并被回滚。失败的步骤:“=> {“操作步骤-1”=> {“WFLYCTL0080:服务失败”=> {“jboss.module.service。\”deployment.aigateway.war \“。main”=> “服务jboss.module.service。”中的org.jboss.msc.service.StartException。部署.aigateway.war \“。main:WFLYSRV0179:无法加载模块:deployment.aigateway.war:main   [错误]引起:org.jboss.modules.ModuleNotFoundException:org.hibernate:ogm“},”WFLYCTL0412:未安装所需的服务:“=> [”jboss.module.service。\“deployment.aigateway。 war \“。main”],“WFLYCTL0180:缺少/不可用依赖项的服务”=> undefined}}}   [错误] - > [帮助1]   [错误]   [错误]要查看错误的完整堆栈跟踪,请使用-e开关重新运行Maven。   [ERROR]使用-X开关重新运行Maven以启用完整的调试日志记录。   [错误]   [错误]有关错误和可能解决方案的更多信息,请阅读以下文章:   [错误] [帮助1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException

这是我的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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.sensorhound</groupId>
<artifactId>aigateway</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>AI Gateway Maven Webapp</name>
<url>http://maven.apache.org</url>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <jetty.version>9.3.12.v20160915</jetty.version>
    <jersey.version>2.23.2</jersey.version>
    <ogm.version>5.0.10.Final</ogm.version>
    <hibernate.version>5.0.10.Final</hibernate.version>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.hibernate.ogm</groupId>
            <artifactId>hibernate-ogm-bom</artifactId>
            <version>5.0.4.Final</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<dependencies>
    <!-- hibernate -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>${hibernate.version}</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-search-orm</artifactId>
        <version>5.5.1.Final</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>${hibernate.version}</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-search-infinispan</artifactId>
        <version>5.1.1.Final</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.hibernate.ogm</groupId>
        <artifactId>hibernate-ogm-cassandra</artifactId>
        <version>5.0.4.Final</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
       <groupId>dom4j</groupId>
       <artifactId>dom4j</artifactId>
       <version>1.6.1</version>
       <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.jboss.logging</groupId>
        <artifactId>jboss-logging</artifactId>
        <version>3.3.0.Final</version>
    </dependency>

    <!-- hibernate ogm -->
    <!-- Hibernate OGM Infinispan module; pulls in the OGM core module -->
    <dependency>
        <groupId>org.hibernate.ogm</groupId>
        <artifactId>hibernate-ogm-infinispan</artifactId>
    </dependency>
    <!-- standard APIs dependencies - provided in a Java EE container -->
    <dependency>
        <groupId>org.hibernate.javax.persistence</groupId>
        <artifactId>hibernate-jpa-2.1-api</artifactId>
    </dependency>
    <dependency>
        <groupId>org.jboss.spec.javax.transaction</groupId>
        <artifactId>jboss-transaction-api_1.2_spec</artifactId>
    </dependency>
    <!-- Add the Narayana Transactions Manager
     an implementation would be provided in a Java EE container,
     but this works nicely in Java SE as well -->
    <dependency>
        <groupId>org.jboss.narayana.jta</groupId>
        <artifactId>narayana-jta</artifactId>
    </dependency>
    <dependency>
        <groupId>org.jboss</groupId>
        <artifactId>jboss-transaction-spi</artifactId>
        <version>7.5.0.Final</version>
    </dependency>
    <dependency>
        <groupId>jboss</groupId>
        <artifactId>jbossjta</artifactId>
        <version>4.2.2.GA</version>
    </dependency>
    <dependency>
        <groupId>org.eclipse.jetty</groupId>
        <artifactId>jetty-server</artifactId>
        <version>${jetty.version}</version>
    </dependency>
    <!-- dependency> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-servlet</artifactId> 
        <version>${jetty.version}</version> </dependency -->
    <dependency>
        <groupId>org.glassfish.jersey.core</groupId>
        <artifactId>jersey-server</artifactId>
        <version>${jersey.version}</version>
    </dependency>
    <dependency>
        <groupId>org.glassfish.jersey.containers</groupId>
        <artifactId>jersey-container-servlet-core</artifactId>
        <version>${jersey.version}</version>
    </dependency>
    <dependency>
        <groupId>org.glassfish.jersey.containers</groupId>
        <artifactId>jersey-container-jetty-http</artifactId>
        <version>${jersey.version}</version>
    </dependency>
    <dependency>
        <groupId>org.fusesource.leveldbjni</groupId>
        <artifactId>leveldbjni-all</artifactId>
        <version>1.8</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/javax.ws.rs/javax.ws.rs-api -->
    <dependency>
        <groupId>javax.ws.rs</groupId>
        <artifactId>javax.ws.rs-api</artifactId>
        <version>2.0</version>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.0.1</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate.javax.persistence</groupId>
        <artifactId>hibernate-jpa-2.0-api</artifactId>
        <version>1.0.1.Final</version>
    </dependency>
    <dependency>
        <groupId>com.googlecode.json-simple</groupId>
        <artifactId>json-simple</artifactId>
        <version>1.1.1</version>
    </dependency>
    <dependency>
        <groupId>javax.ejb</groupId>
        <artifactId>ejb-api</artifactId>
        <version>3.0</version>
    </dependency>
    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-api</artifactId>
        <version>7.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>19.0</version>
    </dependency>
</dependencies>
<build>
    <finalName>aigateway</finalName>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.1</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.wildfly.plugins</groupId>
            <artifactId>wildfly-maven-plugin</artifactId>
            <version>1.1.0.Final</version>
            <configuration>
            <force>true</force>
            <hostname>${wildfly-hostname}</hostname>
            <username>${wildfly-user}</username>
            <password>${wildfly-password}</password>
            </configuration>
        </plugin>
     </plugins>
</build>

这是我的persistence.xml:

<?xml version="1.0"?>
<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="JPAService">
    <!-- Use the Hibernate OGM provider: configuration will be transparent -->
    <provider>org.hibernate.ogm.jpa.HibernateOgmPersistence</provider>
    <properties>
        <property name="hibernate.transaction.jta.platform" value="JBossAS" />
        <property name="jboss.as.jpa.providerModule" value="org.hibernate:5.2.1.Final" />
        <property name="hibernate.ogm.datastore.provider" value="cassandra_experimental"/>
        <property name="hibernate.ogm.datastore.host" value="127.0.0.1:9042"/>
        <property name="hibernate.ogm.datastore.database" value="dev"/>         
    </properties>
</persistence-unit>

这是我的jboss-deployment-structure.xml:

<jboss-deployment-structure>
<deployment>
    <dependencies>
        <module name="org.hibernate" slot="ogm" services="export" />
        <module name="org.hibernate.ogm.cassandra" slot="main" services="export" />
    </dependencies>
</deployment>

我有hibernate ogm所需的模块: $ WILDFLY_HOME /模块/系统/层/基层/组织/休眠/

所以我认为wildfly应该能够找到它。但是当我想部署我的项目时,它给了我那种moduleNutFoundException,我不知道为什么。有人请帮助我。

谢谢!

2 个答案:

答案 0 :(得分:0)

替换

<module name="org.hibernate" slot="ogm" services="export" />

使用:

<module name="org.hibernate.ogm" slot="5.0" services="export" />

此外,您需要将ORM 5.0与OGM 5.0一起使用,ORM 5.2.x将无法使用。

答案 1 :(得分:0)

我已经解决了这个问题。

有关更多信息,请查看: https://developer.jboss.org/thread/274171