【Nginx】相关优化

一、open() min.js.map failed

访问nginx时,提示错误:

2026/02/20 02:43:03 [error] 2369#2369: *336 open() "/home/apps/tomcat/webapps/ROOT/resources/lib/vxe-table/index.umd.min.js.map" failed (2: No such file or directory), client: 59.42.87.52, server: www.demo.com, request: "GET /resources/lib/vxe-table/index.umd.min.js.map HTTP/1.1", host: "www.demo.com"

1.1、原因

浏览器默认会请求 .map 文件(Source Map)用于调试,但是Tomcat里面没有.map文件,或者 Nginx 的 try_files 配置会优先查找本地文件而不是代理到 Tomcat。

1.2、方案

关闭 Source Map 请求即可(如果确实需要,也可以把.map文件部署到服务器)。

复制代码
server {
    listen 80;
    server_name www.demo.com;
    
    location / {
        proxy_pass http://localhost:8080;  # 你的Tomcat地址
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
    
    # 拦截所有 .map 请求,返回 204 No Content,不记录错误日志
    location ~* \.map$ {
        access_log off;
        log_not_found off;
        return 204;
    }
}

1.3、最佳实践

复制代码
server {
    listen 80;
    server_name www.demo.com;
    
    # 日志优化:忽略常见的静态资源找不到错误
    error_log /var/log/nginx/error.log warn;
    
    location / {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
    
    # 可选:直接处理静态资源缓存,减少Tomcat压力
    location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff|woff2|ttf|eot)$ {
        expires 30d;
        add_header Cache-Control "public, immutable";
        
        # 关键:try_files 失败时回源到Tomcat
        try_files $uri @proxy;
    }
    
    location @proxy {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
    }
    
    # 屏蔽 .map 请求,减少无效日志
    location ~* \.map$ {
        access_log off;
        log_not_found off;
        return 204;
    }
}

这里做了几个优化:

1、静态资源直接通过Nginx来处理,减小tomcat的压力

2、屏蔽.map请求,且不记录错误日志

相关推荐
learndiary1 小时前
Linux、Windows双系统根分区扩容要点
linux·运维·扩容·双系统
Doro再努力1 小时前
【Linux操作系统15】深入理解Linux进程概念:从理论到实践
android·linux·运维
webkubor1 小时前
2026 年 把网页交互的主控权拿回前端手中 🚀
前端·javascript·人工智能
余瑜鱼鱼鱼1 小时前
NAT机制总结
运维·服务器·网络
Lee川2 小时前
Promise:驾驭 JavaScript 异步编程的艺术
javascript
暴力求解2 小时前
Linux--重定向
linux·运维·服务器
LongQ30ZZ2 小时前
博客系统测试报告
运维·服务器
Desirediscipline2 小时前
#include<limits>#include <string>#include <sstream>#include <iomanip>
java·开发语言·前端·javascript·算法
逸尘散修2 小时前
Nginx 限流实战全指南:从原理到生产级配置详解
nginx