运行我的 WAR 文件时出现 Tomcat 404 错误

Posted

技术标签:

【中文标题】运行我的 WAR 文件时出现 Tomcat 404 错误【英文标题】:Getting Tomcat 404 error upon running my WAR file 【发布时间】:2014-06-03 04:40:48 【问题描述】:

我收到“请求的资源不可用”。在 Tomcat 7 中部署我的战争时的消息。

这里是详细信息。

1] WAR 名称 = devMonitor-1.war

2] web.xml如下:

<?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_2_5.xsd" id="WebApp_ID" version="2.5">
    <display-name>main</display-name>
    <servlet>
    <servlet-name>Jersey REST Service</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
        <init-param>
        <param-name>com.sun.jersey.config.property.packages</param-name>
        <param-value>main.java</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
    </servlet>
<servlet-mapping>
    <servlet-name>Jersey REST Service</servlet-name>
    <url-pattern>/rest/*</url-pattern>
</servlet-mapping>
</web-app>

3] 我的 Jersey RS 课程

*package main.java;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
//Sets the path to base URL + /hello
**@Path("/hello")**
public class Hello 
    // This method is called if TEXT_PLAIN is request
    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public String sayPlainTextHello() 
        return "Hello Jersey";
    
    // This method is called if XML is request
    @GET
    @Produces(MediaType.TEXT_XML)
    public String sayXMLHello() 
        return "<?xml version=\"1.0\"?>" + "<hello> Hello Jersey" + "</hello>";
    
    // This method is called if html is request
    @GET
    @Produces(MediaType.TEXT_HTML)
    public String sayHtmlHello() 
        return "<html> " + "<title>" + "Hello Jersey" + "</title>" + "<body><h1>" + "Hello Jersey" + "</body></h1>" + "</html> ";
    
    *

4] 我尝试访问的 URL = localhost:8080/main/rest/hello

5] POM文件,如果有如下任何情况

<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>com.travelport.soa.svcs.pos.uapi.devMonitor</groupId>
    <artifactId>devMonitor</artifactId>
    <version>1</version>
    <packaging>war</packaging>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.7</source>
                    <target>1.7</target>
                    <compilerArgument>-Xlint:all</compilerArgument>
                    <showWarnings>true</showWarnings>
                    <showDeprecation>true</showDeprecation>
                </configuration>
            </plugin>
        </plugins>
    </build>
    <dependencies>
        <dependency>
            <groupId>org.glassfish.jersey.core</groupId>
            <artifactId>jersey-server</artifactId>
            <version>2.7</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.containers</groupId>
            <artifactId>jersey-container-servlet-core</artifactId>
            <version>2.7</version>
        </dependency>

    </dependencies>
</project>

6] 我的 tomcat 监视器显示应用程序运行如下,但仍然无法运行。

Path        Version     Display Name        Running     Sessions

/devMonitor-1   None specified  main            true        0   

【问题讨论】:

true 0 表示应用程序不可访问。当您的应用程序成功运行时,它将为真 1 ,因此请尝试重新部署该应用程序。 URI 是 localhost:8080/devMonitor-1/rest/hello 我重新部署了,但会话仍然显示为 0。我该怎么办? @MauricePerry localhost:8080/devMonitor-1/rest/hello 也不起作用。 web.xml 中的显示名称也不应该在 URL 中起作用吗?例如localhost:8080/devMonitor-1/main/rest/hello 没有。此外,您的 tomcat 监视器清楚地显示它在 /devMonitor-1 【参考方案1】:

部署 WAR 文件时需要注意的事项很少。

尝试: 从命令行或管理器应用重新部署 WAR 文件。耐心点。如果您的 WAR 文件很大,这可能需要几分钟。观察任务管理器,看看 Tomcat 使用了多少 CPU。如果它正在使用 90% 或更多,则可能是部署过程未完成。 如果重新部署不起作用,请停止 Tomcat,删除 WAR 文件,在 Web 应用程序文件夹中放置一个新的 WAR 文件,重新启动 Tomcat 并等待部署过程完成。

【讨论】:

我的 WAR 只有 3 MB。在Tomcat 7中部署,它没有显示任何错误。仍然没有任何反应。 :( 除了 2014 年 4 月 18 日 10:50:02 AM org.apache.catalina.core.AprLifecycleListener init 之外的日志 . . 信息:正在启动 Servlet 引擎:Apache Tomcat/7.0.42 Apr 18, 2014 10:50:04 AM org. apache.catalina.startup.HostConfig deployWAR 信息:部署 Web 应用程序归档 C:\apache-tomcat-7.0.42-windows-x64\apache-tomcat-7.0.42\webapps\devMonitor-1.war . . INFO:启动 ProtocolHandler ["http-apr-8080"] 2014 年 4 月 18 日上午 10:50:06 org.apache.coyote.AbstractProtocol 开始 . . 信息:服务器在 1923 毫秒内启动 你是如何编译你的WAR文件的?您是使用 IDE 还是更手动的流程来打包 Web 应用程序? 我正在使用 Maven POM 文件来构建 war 文件。 并通过 Eclipse 作为 Maven 安装运行 您在 Tomcat 日志中的任何文件中都没有错误?

以上是关于运行我的 WAR 文件时出现 Tomcat 404 错误的主要内容,如果未能解决你的问题,请参考以下文章

将 WAR 部署到 AWS Tomcat 404 错误

若依vue项目部署步骤,避免刷新时出现404错误

将war文件部署到Tomcat时出现Elastic Beanstalk 502错误

在Eclipse中启动tomcat后访问tomcat首页时出现404

在Tomcat中部署应用程序时出现错误404

把war包放到Tomcat安装文件夹下,不能直接訪问的解决方式