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