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

相关推荐
IT策士16 分钟前
深入浅出:使用 Gunicorn + Nginx + Docker 将 Django 项目部署到云服务器
nginx·docker·gunicorn
悠然南风1 小时前
Nginx 学习总结-补充
nginx
咚为14 小时前
比AccessLog更全面的原生Nginx 日志记录
运维·nginx·junit
身如柳絮随风扬16 小时前
Nginx 完全指南:核心用途、配置文件详解与动态配置实践
运维·nginx
一个处女座的程序猿O(∩_∩)O16 小时前
如何保持nginx配置与前端打包dist的路径保持一致、解决页面刷新白屏以及页面跳转问题
运维·前端·nginx
椰汁菠萝1 天前
[特殊字符] Nginx UI:Docker 部署与完全使用指南
nginx·ui·docker
yoyo_zzm1 天前
ThinkPHP1.X核心特性解析
数据库·spring boot·nginx
程序员老邢1 天前
【技术底稿 36】Docker Compose 微服务迁移 K3s:离线导入、镜像挂载、Nginx 重定向全踩坑复盘
nginx·docker·云原生·k3s·微服务迁移·技术底稿·容器运维
JiaWen技术圈1 天前
Web 安全防护 介绍
运维·nginx·安全
看到代码头都是大的2 天前
Windows环境下绿色版nginx 1.30使用
运维·nginx