2011-06-10 2 views
0

Я использую jboss6, управляемый сообщениями bean, hibernate и maven2 в своем приложении, когда я пытаюсь скомпилировать свой mdb с помощью maven2 и развернуть на jboss6. Я получаю следующую ошибку:Невозможно развернуть Maven jar (MDB) на Jboss 6

Failed to create Resource MessageBean.jar - cause: java.lang.Exception:Failed to start deployment [vfs:///opt/jboss6/server/default/deploy/MessageBean.jar] during deployment of 'MessageBean.jar' - cause: java.lang.RuntimeException:org.jboss.deployers.client.spi.IncompleteDeploymentException: Summary of incomplete deployments (SEE PREVIOUS ERRORS FOR DETAILS): DEPLOYMENTS MISSING DEPENDENCIES: Deployment "jboss.j2ee:jar=MessageBean.jar,name=MessageBean,service=EJB3" is missing the following dependencies: Dependency "interface org.jboss.ejb3.timerservice.spi.TimerServiceFactory" (should be in state "Installed", but is actually in state "Instantiated") DEPLOYMENTS IN ERROR: Deployment "interface org.jboss.ejb3.timerservice.spi.TimerServiceFactory" is in error due to the following reason(s): Instantiated -> org.jboss.deployers.client.spi.IncompleteDeploymentException:Summary of incomplete deployments (SEE PREVIOUS ERRORS FOR DETAILS): DEPLOYMENTS MISSING DEPENDENCIES: Deployment "jboss.j2ee:jar=MessageBean.jar,name=MessageBean,service=EJB3" is missing the following dependencies: Dependency "interface org.jboss.ejb3.timerservice.spi.TimerServiceFactory" (should be in state "Installed", but is actually in state "Instantiated") DEPLOYMENTS IN ERROR: Deployment "interface org.jboss.ejb3.timerservice.spi.TimerServiceFactory" is in error due to the following reason(s): Instantiated 

Вот мой 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.mycompany</groupId> 
    <artifactId>MessageBean</artifactId> 
    <packaging>ejb</packaging> 
    <version>1.0-SNAPSHOT</version> 
    <name>MessageBean Java EE 6 EJB</name> 
    <url>http://maven.apache.org</url> 

    <dependencies> 
     <dependency> 
      <groupId>log4j</groupId> 
      <artifactId>log4j</artifactId> 
      <version>1.2.12</version> 
     </dependency> 
     <dependency> 
      <groupId>org.jboss.ejb3</groupId> 
      <artifactId>jboss-ejb3-timerservice-spi</artifactId> 
      <version>1.0.4</version> 
     </dependency> 

     <dependency> 
      <groupId>org.hibernate</groupId> 
      <artifactId>hibernate</artifactId> 
      <version>3.0</version> 
      <type>jar</type> 
      <scope>compile</scope> 
     </dependency> 
     <dependency> 
      <groupId>org.jboss.ejb3</groupId> 
      <artifactId>jboss-ejb3-ext-api</artifactId> 
      <version>1.0.0</version> 
     </dependency> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>jcl-over-slf4j</artifactId> 
      <version>1.5.6</version> 
      <scope>test</scope> 
     </dependency> 
     <dependency> 
      <groupId>org.slf4j</groupId> 
      <artifactId>slf4j-api</artifactId> 
      <version>1.5.6</version> 
      <scope>test</scope> 
     </dependency> 
     <dependency> 
      <groupId>javax</groupId> 
      <!-- 
      <artifactId>javaee-web-api</artifactId> 
      --> 
      <artifactId>javaee-api</artifactId> 

      <version>6.0</version> 
      <!-- Added below --> 
      <type>jar</type> 
<!--      modified by varsha --> 
      <scope>provided</scope> 
      <!-- end --> 
     </dependency> 
<!--  <dependency> 
      <groupId>org.jboss.ejb3</groupId> 
      <artifactId>jboss-ejb3-ext-api-impl</artifactId> 
      <version>1.1.1</version> 
     </dependency>--> 

     <dependency> 
      <groupId>javax</groupId> 
      <artifactId>javaee-api</artifactId> 
      <version>6.0</version> 
      <scope>provided</scope> 
     </dependency> 
     <dependency> 
      <groupId>junit</groupId> 
      <artifactId>junit</artifactId> 
      <version>3.8.2</version> 
      <scope>test</scope> 
     </dependency> 

    </dependencies> 

    <repositories> 
     <repository> 
      <id>java.net2</id> 
      <name>Java.Net Maven2 Repository, hosts the javaee-api dependency</name> 
      <url>http://download.java.net/maven/2</url> 
     </repository> 
     <repository> 
      <id>jboss-public-repository-group</id> 
      <name>JBoss Public Maven Repository Group</name> 
      <url>https://repository.jboss.org/nexus/content/groups/public-jboss/</url> 
      <layout>default</layout> 
      <releases> 
       <enabled>true</enabled> 
       <updatePolicy>never</updatePolicy> 
      </releases> 
      <snapshots> 
       <enabled>true</enabled> 
       <updatePolicy>never</updatePolicy> 
      </snapshots> 
     </repository> 
     <repository> 
      <id>jboss</id> 
      <url>http://repository.jboss.com/maven2</url> 
      <releases> 
       <enabled>true</enabled> 
      </releases> 
      <snapshots> 
       <enabled>false</enabled> 
      </snapshots> 
     </repository> 
     <repository> 
      <id>jboss-snapshot</id> 
      <url>http://snapshots.jboss.org/maven2</url> 
      <releases> 
       <enabled>true</enabled> 
      </releases> 
      <snapshots> 
       <enabled>true</enabled> 
      </snapshots> 
     </repository> 

    </repositories> 

    <build> 
     <plugins> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <version>2.0.2</version> 
       <configuration> 
        <source>1.6</source> 
        <target>1.6</target> 
       </configuration> 
      </plugin> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-ejb-plugin</artifactId> 
       <version>2.1</version> 
       <configuration> 
        <ejbVersion>3.1</ejbVersion> 
       </configuration> 
      </plugin> 


      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <version>2.3.2</version> 
       <configuration> 
        <source>1.6</source> 
        <target>1.6</target> 
       </configuration> 
      </plugin> 
      <plugin> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <configuration> 
        <source>1.5</source> 
        <target>1.5</target> 
       </configuration> 
      </plugin> 
      <plugin> 
       <artifactId>maven-war-plugin</artifactId> 
       <version>2.0</version> 
      </plugin> 

<!--   <plugin> 
       <groupId>org.codehaus.mojo</groupId> 
       <artifactId>jboss-maven-plugin</artifactId> 
       <version>1.5.0</version> 
       <configuration> 

        <jbossHome>/opt/jboss6/server/default/deploy</jbossHome> 

        <jbossHome>/home/varsha/Downloads/jboss-6.0.0.Final/</jbossHome> 
        <serverName>default</serverName> 
        <fileName>target/MessageBean.jar</fileName> 
        <path>/UltimateSMS</path> 
       </configuration> 
      </plugin>--> 
     </plugins> 
     <finalName>MessageBean</finalName> 
    </build> 
    <profiles> 
     <profile> 
      <id>endorsed</id> 
      <activation> 
       <property> 
        <name>sun.boot.class.path</name> 
       </property> 
      </activation> 
      <build> 
       <plugins> 
        <plugin> 
         <groupId>org.apache.maven.plugins</groupId> 
         <artifactId>maven-compiler-plugin</artifactId> 
         <version>2.0.2</version> 
         <dependencies> 
          <dependency> 
           <groupId>javax</groupId> 
           <artifactId>javaee-endorsed-api</artifactId> 
           <version>6.0</version> 
          </dependency> 
         </dependencies> 
        </plugin> 
       </plugins> 
      </build> 
     </profile> 
    </profiles> 
</project> 

Я не использую таймер ejb3 в моем приложении, как сейчас

Что, кажется, проблема? пожалуйста, помогите :(

ответ

0

Похоже на время вашего .jar то развертывания уже реализованным в TimerServiceFactory.

Проверьте зависимости, я когда-то была аналогичная проблема, когда одна из банок я имел как мавена зависимость фактически имела jboss.xml в своей папке META-INF и была привязана к bean-компоненту, который я использовал для имени JNDI, которое я уже использовал.

Его боль, чтобы искать ваши зависимости, но это выглядит как противоречивое с чем-то .

Возможно, что один из ваших зависимых лиц ncies зависит от более старой версии interface org.jboss.ejb3.timerservice.spi.TimerServiceFactory, и она получает экземпляр перед вашим.

Проверьте папку .m2 и проверьте, есть ли у вас 2 версии jboss-ejb3-timerservice-spi.

2

денденция «jboss-ejb3-timerservice-spi», скорее всего, ваша проблема. не знаете, почему вам нужно зависеть от этого, но вы, конечно, не должны включать его в развертывание. если вы по каким-то причинам do, то он должен быть помечен как область действия «предоставлена». все эти зависимости jboss и любые другие те банки, которые находятся в каталоге jboss lib, должны быть отмечены как область «предоставлена». как правило, ваше приложение не должно содержать банок, которые являются частью сервера jboss.

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