Nginx代理api出现response body内容被截断问题处理

问题现象(相同问题

通过nginx服务器代理后的API,response body内容被截断。字符串不完整。导致JSON解析报错。

原因分析

查看nginx日志,可以发现类似这样的错误信息:
2017/04/19 13:16:28 [crit] 1879#0: *10035158 mkdir() "/usr/local/nginx/proxy_temp/0/91" failed (13: Permission denied) while reading upstream, client: 10.89.168.135, server: localhost, request: "GET /api/topic/2258 HTTP/1.0", upstream: "http://localhost:8080/guest/topic/2258", host: "my.com", referrer: "http://my.com/topic/"
错误信息显示,nginx向/usr/local/nginx/proxy_temp/目录下写入了临时数据,而执行nginx的用户没有该目录的写入权限。
因为nginx对于返回值字符数小的请求直接使用内存作中转,对于数据量大的请求,使用文件系统来做中转。由于权限不够,返回时只返回了部分字符,导致出现此问题。

解决办法

给nginx账户分配足够的权限,或者切换成其他有权限的账户。
注:nginx账户配置,在nginx.conf 文件的第一行。user root;

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ITdada

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值