问题描述

通过网页获取数据,数据格式为xml。当xml比较短时,可以正常获取数据。但是xml长度过长时不能正常获取数据,通过观察返回数据的源代码,发现xml被截断了。

服务器环境

  • CentOS 6.5
  • Nginx 1.0.15
  • PHP 5.3.3

解决方法

对比发现,使用apache代替nginx的时候可以正常获取长的xml数据。确定问题出现在nginx的配置上。

查看ngnix日志(yum安装默认目录:/var/log/nginx/)发现问题所在。

2015/01/26 13:38:07 [crit] 2316#0: *33 open() "/var/lib/nginx/tmp/fastcgi/1/01/0000000011" failed (13: Permission denied) while reading upstream, client: 192.16    8.56.1, server: , request: "GET /index.php?param=****** HTTP/1.1", upstream: "fastcgi://127.0    .0.1:9000", host: "centos.ctrip.dev:8001"

问题出现在此时nginx临时向/var/lib/nginx/tmp/目录下写入了临时数据,而执行nginx的用户没有该目录的写入权限。

解决该权限问题后问题解决。


coder_ss
830 声望19 粉丝