nginx 404 not found错误查找

博客围绕通过nginx转发请求时,数据量大报错404 not found的问题展开。介绍了系统架构,包括浏览器、前端、后端及DataService间通过nginx的访问关系。经定位,发现是nginx临时文件夹权限问题,大数据量参数需缓存到磁盘创建临时文件,而onlineUser无权限导致创建失败。

问题

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

### 解析 Nginx 404 Not Found 错误服务器返回 `404 Not Found` 错误时,意味着客户端尝试访问的资源在服务器上不存在。对于Nginx而言,这通常是因为请求路径未能匹配任何实际存在的文件或未被正确转发给应用程序处理。 #### 文件位置不正确 如果直接访问域名如 app.test.cc,则请求会被导向至 `/home/app/login/jboss/webapps` 下查找默认首页文件(例如 index.jsp, index.htm 或者 index.html)。一旦这些指定的入口文件缺失于该目录内,便会触发404响应[^1]。 #### 路由配置不当 针对基于PHP框架的应用程序(比如Laravel),即使根路径可以成功加载,其他自定义路由可能会因为缺少必要的重写规则而遭遇404错误。特别是当试图隐藏index.php时,如果没有适当调整location块中的try_files指令来支持干净URL模式的话,就容易发生此类情况[^3]。 #### 配置文件语法错误 另外,在修改Nginx配置过程中引入了非法字符或是遗漏某些必要符号也会造成服务端解析失败并给出类似的提示信息。因此建议使用专业的文本编辑工具而非简单的记事本来编辑.conf文件以减少潜在的风险因素[^4]。 为了有效解决上述提到的各种原因引起的404问题: ```nginx server { listen 80; server_name localhost; root /path/to/your/project/public; # 确认此路径指向项目public目录 location / { try_files $uri $uri/ /index.php?$query_string; } location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/var/run/php/php7.x-fpm.sock; # 根据实际情况替换版本号 } } ``` 这段代码展示了如何通过设置正确的root路径以及利用try_files命令让所有未知URI最终都交由index.php处理的方式,从而避免因找不到具体文件而导致的404错误。同时确保fastcgi部分能够顺利传递PHP请求给后端解释器执行。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值