【Nginx】Nginx代理Tomcat配置及404问题解决

当Tomcat返回HTTP 404未找到 错误时,可以通过以下两种方式设置跳转到指定地址:
① 在Tomcat应用内部配置错误页面跳转 (直接修改Tomcat的Web应用配置)
② 在Nginx反向代理层拦截404错误并跳转(无需修改Tomcat,由Nginx统一处理)。

以下是具体配置方法:


方法1:在Tomcat应用中配置404跳转(修改web.xml)

适用于直接控制Tomcat应用的情况,通过定义错误页面实现跳转。

步骤:
  1. 修改应用的web.xml文件

    在Tomcat应用的WEB-INF/web.xml(或全局的conf/web.xml)中添加以下配置:

    xml 复制代码
    <!-- 定义404错误跳转到指定路径 -->
    <error-page>
        <error-code>404</error-code>
        <location>/custom-404.html</location>  <!-- 跳转到应用内的静态页面 -->
        <!-- 或跳转到外部URL -->
        <!-- <location>https://example.com/not-found</location> -->
    </error-page>
  2. 创建自定义错误页面(可选)

    如果跳转到应用内页面(如/custom-404.html),需在Web应用的根目录下创建对应文件。

  3. 重启Tomcat生效

    bash 复制代码
    # 重启Tomcat服务
    sudo systemctl restart tomcat

方法2:在Nginx反向代理层拦截404并跳转

适用于通过Nginx代理Tomcat的场景,无需修改Tomcat配置,直接在Nginx中处理错误。

步骤:
  1. 修改Nginx配置文件

    在Nginx的server块中添加以下配置,拦截Tomcat返回的404错误并重定向:

    nginx 复制代码
    server {
        listen 443 ssl;
        server_name example.com;
    
        # SSL配置...
    
        # 代理到Tomcat
        location / {
            proxy_pass http://tomcat-server:8080;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-Proto $scheme;
    
            # 关键配置:启用错误拦截
            proxy_intercept_errors on;
        }
    
        # 捕获404错误并跳转到指定地址
        error_page 404 =301 https://example.com/not-found;
        # 或跳转到静态页面
        # error_page 404 /custom-404.html;
        # location = /custom-404.html {
        #     root /usr/share/nginx/html;
        #     internal;  # 仅允许内部访问
        # }
    }
  2. 验证并重载Nginx

    bash 复制代码
    # 检查配置语法
    sudo nginx -t
    
    # 重新加载配置
    sudo nginx -s reload

验证跳转是否生效

  • 访问一个不存在的URL
    例如 https://example.com/non-existent-path,观察是否自动跳转到指定地址。

  • 使用curl测试

    bash 复制代码
    curl -v https://example.com/non-existent-path

    检查响应头中的 Location 字段(跳转时)或返回的自定义页面内容。


常见问题排查

  1. Tomcat未返回真实404状态码
    确保Tomcat应用在资源不存在时正确返回404(而非其他状态码如500)。
  2. Nginx未启用proxy_intercept_errors
    必须设置 proxy_intercept_errors on;,否则Nginx不会处理后端返回的错误码。
  3. 路径或权限问题
    • 检查自定义错误页面的路径是否存在且可读。
    • 确认Nginx配置中的跳转地址可公开访问(如外部URL需有效)。

总结

  • 若需灵活控制跳转逻辑(如动态重定向),优先使用Nginx配置。
  • 若需保持应用独立性 (如不同应用有不同的404页面),优先修改Tomcat的web.xml

根据实际场景选择合适方案即可解决404跳转问题!

相关推荐
乘云数字DATABUFF4 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--6 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森6 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜7 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB8 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode9 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户03284722207010 天前
如何搭建本地yum源(上)
运维
ping某11 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
大树8813 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠13 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql