nginx导致的返回内容缺少

问题描述:

在个人电脑执行curl后返现接口仅返回部分内容,出参感觉被截取少了一部分;但是在服务所在机器上直接执却发现能返回完整信息

后来就了解到,个人电脑和服务器电脑的差别是是否走了nginx,所以出问题的地方可能是nginx

nginx的错误日志如下:

2024/04/16 11:43:41 [crit] 29434#0: *550562 open() "/opt/nginx/proxy_temp/1/29/0000000291" failed (13: Permission denied) while reading upstream, client: 10.14.168.15, server: 10.14.250.23, request: "GET /api/coursewareInfoByIdCnum?id=93f63bb7ecbc4c498b889fcfa90d7c37&cnum=19 HTTP/1.1", upstream: "http://127.0.0.1:11121/api/coursewareInfoByIdCnum?id=93f63bb7ecbc4c498b889fcfa90d7c37\&cnum=19", host: "10.14.250.23"

然后查看nginx的配置发现,nginx进程对应的用户是普通用户beibo,路径/opt/nginx/proxy_temp是属于root用户的,

执行如下指令,将/opt/nginx/proxy_temp的所有者修改为beibo

sudo chown -R beibo /opt/nginx/proxy_temp

然后重新执行对应的curl,出参完整,解决问题。

原因分析:

nginx存在一个buffer的机制,在返回数据过大超出缓存区的最大容量时,会将数据写入临时文件,而此时如果安装nginx的用户权限对该目录没有权限,就会报没权限的问题,所以在返回数据时,超出缓存区的数据将丢失,出现截断。所以将nginx的目录赋予权限就可以了

参考:

nginx 返回数据被截断_nginx使网参数被自动截断-CSDN博客

https://blog.51cto.com/u_39037/10073798

相关推荐
洛菡夕13 小时前
nginx安全防护与HTTPS部署实战
nginx·安全·https
刘晨鑫117 小时前
Nginx性能调优
运维·nginx
**蓝桉**17 小时前
prometheus监控nginx
nginx·elasticsearch·prometheus
sszdzq21 小时前
docker 安装 Nginx
nginx·docker·容器
我爱学习好爱好爱1 天前
ELK 7.17.10 + Redis 5.0.7 构建高可用 Nginx 日志收集系统(Rocky Linux 9.6 实战)
redis·nginx·elk
kc胡聪聪1 天前
nginx的性能优化与监控
运维·nginx·性能优化
zzh0811 天前
nginx安全笔记
笔记·nginx·安全
A10169330711 天前
Nginx 之Rewrite 使用详解
运维·nginx
vanvivo2 天前
Nginx中如何配置WebSocket代理?
运维·websocket·nginx
Java小白笔记2 天前
Nginx中配置IP白名单动态刷新
运维·tcp/ip·nginx