nginx 404 not found错误查找

问题

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

架构

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

flowchart LR
    浏览器 --> nginx:8001 --> 前端
    浏览器 --> nginx:8002 --> 后端
    后端 --> nginx:8003 --> DataService
    

后端 通过 nginx 访问DataService 报错

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

问题定位过程

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

client_max_body_size 300M;

问题依旧存在。

查看 nginx的log文件:

logs/error.log

内容如下:

*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),

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的数据量变大,将会缓存到磁盘,需要创建临时文件。临时文件夹没有权限,所以创建文件失败,所以才会无法找到文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值