在Glassfish部署期间,WEB-INF/lib中的JAR库没有添加到类路径中



我是Glassfish和Java EE的新手,尽管我已经使用Java好几年了。我继承了一个停滞不前的项目,现在我需要重新开始开发它。我试图部署的web应用程序是,看看什么工作,什么需要注意。虽然有大量的代码来实现各种功能,但需要注意的第一点似乎是应用程序的部署。

我尝试部署的web应用程序是MyServer,并打包在WAR存档中。MyServer中的一个类引用了MyDatabase中的一个类,该类实现了MyInterfaces中的一个接口(InterfaceOne)。MyServer中的类也从MyInterfaces直接引用InterfaceOneMyServerMyDatabaseMyInterfaces都是Eclipse中的项目,使用Maven进行打包。MyServer的POM文件将MyDatabase列为依赖项,MyDatabase的POM文件将MyInterfaces列为依赖项。MyServer POM文件没有将MyInterfaces列为直接依赖项,但我不认为这会导致问题。Eclipse在MyServer类中没有显示任何错误;Eclipse似乎认为Maven依赖项足以定位所有必要的类。

当我通过Admin web控制台在Glassfish v3.1.2上部署MyServer WAR时,然后查看~glassfish3/glassfish/domains/MyDomain/logs/server.log的日志,我遇到以下错误:

[#|2014-05-29T10:06:02.371+0100] SEVERE|glassfish3.1.2|global| _threaddid =80;_ThreadName=Thread-2;| Class [my/interfaces/InterfaceOne] not found。加载[class my.server.ControllerOne]|#]时出错[#|2014-05-29T10:06:02.387+0100] SEVERE|glassfish3.1.2|global| _threaddid =80;_ThreadName=Thread-2;|类[my/interfaces/InterfaceOne]未找到加载[class my.server.ControllerOne]|#]

时出错

在尝试从MyServer加载类时,显示了两个与接口相关的错误。如果我从my.server.ControllerOne类中删除对MyDatabase的引用或从MyInterfaces中删除对InterfaceOne的直接引用,那么上述错误之一就会消失(这是预期的,并且只是确认错误与MyInterfaces中对InterfaceOne的引用(直接和间接)相关。

类似的问题包括这里,这里和这里都提到确保所需的库(my-database.jarmy-interfaces.jar)位于MyServer应用程序的WAR存档的WEB-INT/lib目录中。但是,如果我检查为MyServer生成的WAR归档文件,那么这些库确实位于WEB-INF/lib/目录中。如果我在部署后检查~glassfish3/glassfish/domains/MyDomain/applications/MyServer/WEB-INF/lib/目录,库也在那里。我假设这表明它们已经成功地从WAR存档中提取出来并放置在Glassfish服务器上。关键是图书馆肯定在那里!

我所能想到的是,这些库没有添加到JVM的类路径中,试图加载MyServer的类,但如果Glassfish试图加载应用程序的类,那么它也应该首先加载与应用程序打包的库,不是吗?事实上,这一页来自Oracle GlassFish服务器应用程序开发指南3.1.2版本表明应用程序的WEB-INF/lib/目录被添加到应用程序的类路径中。

我看到其他建议,web应用程序所需的库放在~glassfish3/glassfish/domains/MyDomain/lib/ext/目录。这可能会很好地工作,但是我的特定库只需要MyServer应用程序,而不是整个MyDomain。据我所知,将它们放在应用程序的WEB-INF/lib/目录中应该是有效的。

有没有人知道为什么my-database.jarmy-interfaces.jar库在部署期间似乎没有添加到类路径中?更具体地说,有没有人知道为什么my.interfaces.InterfaceOne类在部署期间加载my.server.ControllerOne类时不可见?

MyServer 's web.xml content:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>MyServer</display-name>
  <welcome-file-list>
    <welcome-file>index.xhtml</welcome-file>
    <welcome-file>default.xhtml</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>Faces Servlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Faces Servlet</servlet-name>
    <url-pattern>/faces/*</url-pattern>
  </servlet-mapping>
  <context-param>
    <description>State saving method: 'client' or 'server' (=default). See JSF Specification 2.5.2</description>
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>client</param-value>
  </context-param>
  <context-param>
    <param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name>
    <param-value>resources.application</param-value>
  </context-param>
  <context-param>
    <param-name>javax.faces.FACELETS_LIBRARIES</param-name>
    <param-value>/WEB-INF/balusc.taglib.xml</param-value>
  </context-param>
  <context-param>
    <param-name>javax.faces.INTERPRET_EMPTY_STRING_SUBMITTED_VALUES_AS_NULL</param-name>
    <param-value>true</param-value>
  </context-param>
  <filter>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
  </filter-mapping>
  <context-param>
    <param-name>javax.faces.PARTIAL_STATE_SAVING</param-name>
    <param-value>false</param-value>
  </context-param>
</web-app>

MyServer 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.webapp</groupId>
    <artifactId>my-server</artifactId>
    <version>0.1.0-SNAPSHOT</version>
    <name>My Server</name>
    <parent>
        <groupId>my.webapp</groupId>
        <artifactId>my-parent-pom</artifactId>
        <version>1.5</version>
    </parent>
    <organization>
        <name>Example</name>
        <url>http://www.example.com</url>
    </organization>
    <repositories>
        <repository>
            <id>eclipselink</id>
            <url>http://www.eclipse.org/downloads/download.php?r=1&amp;nf=1&amp;file=/rt/eclipselink/maven.repo/</url>
        </repository>
    </repositories>
    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>6.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>javax.faces</groupId>
            <artifactId>jsf-api</artifactId>
            <version>2.1</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.sun.faces</groupId>
            <artifactId>jsf-impl</artifactId>
            <version>2.1.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>eclipselink</groupId>
            <artifactId>eclipselink</artifactId>
            <version>2.3.0</version>
        </dependency>
        <dependency>
            <groupId>utilities</groupId>
            <artifactId>utilities</artifactId>
            <version>0.1.0</version>
        </dependency>
        <dependency>
            <groupId>javax.enterprise</groupId>
            <artifactId>cdi-api</artifactId>
            <version>1.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>my.webapp</groupId>
            <artifactId>my-database</artifactId>
            <version>0.1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.primefaces</groupId>
            <artifactId>primefaces</artifactId>
            <version>3.4.1</version>
        </dependency>
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-io</artifactId>
        <version>1.3.2</version>
    </dependency>
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.2.1</version>
    </dependency>
    </dependencies>
    <packaging>war</packaging>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <!-- <configuration> section added to pick up the WEB-INF/web.xml inside
                    WebContent -->
                <configuration>
                    <webResources>
                        <resource>
                            <directory>WebContent</directory>
                        </resource>
                    </webResources>
                </configuration>
            </plugin>
        </plugins>
    </build>
    <scm>
        <connection>scm:svn:https://svn.server/location/in/repo/my_server</connection>
        <developerConnection>scm:svn:https://svn.server/location/in/repo/my_server/trunk</developerConnection>
    </scm>
</project>

MyDatabase 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>
  <artifactId>my-database</artifactId>
  <version>0.1.0-SNAPSHOT</version>
  <parent>
    <groupId>my.webapp</groupId>
    <artifactId>my-parent-pom</artifactId>
    <version>1.5</version>
  </parent>
  <dependencies>
    <dependency>
      <groupId>eclipselink</groupId>
      <artifactId>eclipselink</artifactId>
      <version>2.3.0</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.10</version>
        <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.mindrot</groupId>
      <artifactId>bcrypt</artifactId>
      <version>0.2.0</version>
    </dependency>
    <dependency>
        <groupId>my.webapp</groupId>
        <artifactId>my-interfaces</artifactId>
        <version>0.1.0-SNAPSHOT</version>
    </dependency>
    <dependency>
        <groupId>org.apache.geronimo.specs</groupId>
        <artifactId>geronimo-jpa_3.0_spec</artifactId>
        <version>1.1.1</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.0.5</version>
        <scope>test</scope>
    </dependency>
  </dependencies>
  <scm>
    <connection>scm:svn:https://svn.server/location/in/repo/my_database</connection>
    <developerConnection>scm:svn:https://svn.server/location/in/repo/my_database/trunk/</developerConnection>
  </scm>
  <groupId>my.webapp</groupId>
</project>

MyInterfaces 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.webapp</groupId>
  <artifactId>my-interfaces</artifactId>
  <version>0.1.0-SNAPSHOT</version>
   <packaging>jar</packaging>
  <parent>
      <groupId>my.webapp</groupId>
      <artifactId>my-parent-pom</artifactId>
      <version>1.5</version>
  </parent>
  <scm>
    <connection>scm:svn:https://svn.server/location/in/repo/my_interfaces</connection>
    <developerConnection>scm:svn:https://svn.server/location/in/repo/my_interfaces/trunk</developerConnection>
  </scm>
  <dependencies>
    <dependency>
        <groupId>my.webapp</groupId>
        <artifactId>my-utilities</artifactId>
        <version>0.1.2</version>
        <classifier>me</classifier>
    </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>4.10</version>
      <scope>test</scope>
    </dependency>
      </dependencies>
</project>

MyInterfaces POM列出了对MyUtilities的依赖。我认为这可以安全地忽略这个问题,因为它的类都没有出现在我所描述的错误消息中。当我的应用程序部署时,它也被放置在Glassfish服务器的WEB-INT/lib/目录中。

(Glassfish问题似乎需要大量的信息,如web.xml文件和pom.xml等。谢谢你花时间筛选所有这些

我已经建立了一个与您所描述的基本相同结构的项目,我无法重现问题,也没有额外的想法可能是错的。

因此,我已经把我的测试项目推到GitHub上,所以你可以尝试一下,也许你会发现你的项目有什么不同。

项目在这里:https://github.com/erdbeerschnitzel/war-packaging

如果你没有一个GitHub帐户来克隆项目,你可以下载ZIP(右下角的按钮)。将其提取到某个地方并加载到IDE中的5个项目,构建所有内容并部署my-server项目的WAR文件。

我省略了父项目,并删除了一些依赖项,如eclipselink和primefaces,但我认为这应该不会有什么不同。

好运。更新:

Glassfish有单独的Deploy和Launch操作。我希望Deploy上传、提取WAR并注册任何需要的内容注册。我希望Launch动作实际加载类和开始流程。为什么在部署时要加载类?

实际上,应用程序(以及类)是在部署时加载的。

似乎有两个问题在起作用:

  1. 首先MyServer's web.xml <display-name>错误。这在我的问题中不可见,因为我更改了库的名称(其中包含客户端名称)。这是给我的要求之一为项目重新命名,我错过了<display-name>元素。哎呀。

  2. 第二个问题是,虽然为了调查这个问题,我移动了MyDatabaseMyInterfaces库来自MyServer WEB-INF/lib/目录到域的lib/ext/目录并返回。这更改了部署期间(自库以来)记录的错误可见,尽管不正确的<display-name>,但他们的错误当我移动数据库和接口库时没有重新出现回到MyServer应用程序。我认为Glassfish正在缓存期间没有更新缓存的库部署。停止/启动已更新缓存的域

总结一下,一旦MyServer的<display-name>被更改并且Glassfish库缓存被更新,类加载错误似乎就解决了。

最新更新