使用Eclipse WTP部署到Glassfish 3.1.2时,EAR中打包的WAR无法启动

时间:2013-06-19 11:49:38

标签: maven glassfish java-ee-6 ear m2e

我有一个基于https://netbeans.org/kb/docs/javaee/maven-entapp.html的JEE6 webapp,结构如下。

foo
foo/foo-ear
foo/foo-web
foo/foo-ejb

顶级项目是聚合器,其他项目分别是ear / war / ejb类型。

我在foo-ear配置了耳塞:

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-ear-plugin</artifactId>
            <version>2.8</version>
            <configuration>
                <version>6</version>
                <defaultLibBundleDir>lib</defaultLibBundleDir>
                <modules>
                    <ejbModule>
                        <groupId>com.foo</groupId>
                        <artifactId>foo-ejb</artifactId>
                    </ejbModule>
                    <webModule>
                        <groupId>com.foo</groupId>
                        <artifactId>foo-web</artifactId>
                    </webModule>
                </modules>
            </configuration>

        </plugin>

运行mvn clean install时,一切正常。

生成application.xml:

<?xml version="1.0" encoding="UTF-8"?>
<application xmlns="http://java.sun.com/xml/ns/javaee"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/application_6.xsd" version="6">
<display-name>foo-ear</display-name>
<module>
    <ejb>foo-ejb-0.1.0-SNAPSHOT.jar</ejb>
</module>
<module>
    <web>
        <web-uri>foo-web-0.1.0-SNAPSHOT.war</web-uri>
        <context-root>/foo-web</context-root>
    </web>
</module>
<library-directory>lib</library-directory>
</application>

在Eclipse中将耳朵添加到GlassFish 3.1.2服务器后,我看到以下日志:

INFO: keepstate options resolved to true, saving appId 89891727150219264 for application foo-ear.
INFO: EJB5181:Portable JNDI names for EJB UserService: [java:global/foo-ear/foo-ejb-0.1.0-SNAPSHOT/UserService!com.foo.user.service.UserService, java:global/foo-ear/foo-ejb-0.1.0-SNAPSHOT/UserService]
INFO: foo-ear was successfully deployed in 78 milliseconds.

与服务器的任何类型的交互都会导致找不到资源。我以前运行过vanilla webapps并回想起在启动时看到JSF / Facelets日志输出。

在其他场合我得到了

SEVERE: Exception while deploying the app [foo-ear] : Could not find sub module [foo-web-0.1.0-SNAPSHOT.war] as defined in application.xml

但我可以看到战争存在的目标。

使用管理控制台手动部署时,EAR正确部署 - 所以m2e-WTP插件是否有问题呢?遗憾的是,它似乎无法识别网络模块。

1 个答案:

答案 0 :(得分:0)

要清楚解决这个问题的方法是什么。

重启eclipse,问题解决了。