• nginx 404 not found错误查找


    问题

    通过nginx转发请求,有的时候好用,有的时候报错:404 not found。
    经过定位:请求参数数据量小,访问正常;请求参数数据量大,访问异常。

    架构

    浏览器通过nginx获取前端代码。
    浏览器前端展示,通过nginx访问 后端。
    后端 通过 nginx 访问DataService。

    flowchart LR
        浏览器 --> nginx:8001 --> 前端
        浏览器 --> nginx:8002 --> 后端
        后端 --> nginx:8003 --> DataService
        
    
    • 1
    • 2
    • 3
    • 4
    • 5

    后端 通过 nginx 访问DataService 报错

    不是全部的请求报错,当请求的数据量达到一定规模,才会报错。
    例如,选择删除一条数据,访问正常。
    删除100条数据,nginx抛错:404 not found。

    问题定位过程

    第一次碰见这个问题,完全是懵逼状态。有的时候好用,有的时候不好用是最难的。
    经过试错,发现在请求的数据量大的情况下,会报错。
    更换 后端的版本,问题依旧存在。
    更换 DataService 问题依旧存在。
    更换 nginx,问题没了。
    第一反应,是nginx的body大小限制,上网查,更改 client_max_body_size。默认为1M。

    client_max_body_size 300M;
    
    • 1

    问题依旧存在。

    查看 nginx的log文件:

    logs/error.log
    
    • 1

    内容如下:

    *3306 open() "/app/nginx/client_body_temp/000000007" failed (2:No such file or directory), client: 10.10.10.112, server:...
    *3306 open() "/app/nginx/html/50x.html"  failed (2:No such file or directory),
    
    • 1
    • 2

    nginx 无法打开文件:/app/nginx/client_body_temp/000000007
    一般无法打开文件,都是因为权限问题。
    于是查看/app/nginx/client_body_temp/的权限,果然如此。
    我们使用的为:onlineUser 部署,没有sudo权限。
    但是测试开发人员有的时候会使用root操作服务器,例如用root启动nginx。
    root操作nginx后,一些文件夹就变成root用户权限。onlineUser没有操作的权限。
    我再使用onlineUser启动nginx。虽然可以正常启动但是有些目录没有权限。
    nginx在参数是小数据量时候,参数都放在内存中。
    当参数body的数据量变大,将会缓存到磁盘,需要创建临时文件。临时文件夹没有权限,所以创建文件失败,所以才会无法找到文件。

  • 相关阅读:
    认识SQL注入
    Eclipse在tomcat运行点击跳转404
    程序员节的由来
    Navicat 解决隔一段时间不操作出现延时卡顿问题
    vue实现stompjs+websocket和后端通信(二)
    我要写整个中文互联网界最牛逼的JVM系列教程 | 「JVM与Java体系架构」章节:为什么要学习JVM?
    Django和Mysql数据库
    基于kolla的openstack在线变更网卡(bond)
    影单:分享一下最近在看的一些电影
    基于Monkey的稳定性测试
  • 原文地址:https://blog.csdn.net/wangyunzhong/article/details/127588818