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;

 

 

你可能感兴趣的:(nginx)