记录一次解决PHP返回数据被nginx截断的问题

博客记录了作者遇到PHP接口返回数据被nginx截断的难题。问题出现在新增的3台服务器上,原因是nginx的buffer机制,当数据超出缓冲区时,无法写入fastcgi_temp目录导致数据丢失。解决方案是检查并调整nginx配置,确保fastcgi_temp目录有正确权限,并合理设置fastcgi_buffer_size和fastcgi_buffers。
摘要由CSDN通过智能技术生成

前言

今日,发生了一件懵逼的事情,通过内部接口获取数据的时候,概率性出现返回的数据被截断的问题。内部接口好好的为何突然出现问题了?此文将记录这次本应该很快解决却没有很快解决的过程。

正文

背景

内部接口分为5+3=8台机器,为什么这么说呢,5台是一直有的,而3台是刚新增的,问题就出在了这三台,由于负载均衡策略所以出现在前文说到的概率性出现返回的数据被截断的问题。

一般开发是没有机器权限的,在不申请临时机器权限的情况下。解决速度完全取决于运维,无果。

发现过程

1.先是四处埋点记日志,确认原因是日志被截断了。
2.由于无线上机器权限所以只好通过跳板机到拟真环境进行

curl -H 'Host:internal.xxx.com' '192.168.xx.xx/data/get_list.json?xxx=xxx'

操作来定位哪台机器出问题了。
是的,8台机器都试过去发现,真的是新增的3台有问题。
3.进一步确认机器上nginx的error日志报错了一堆:

2016/06/07 00:41:28 [crit] 32763#0: *5439 open() "/usr/local/nginx/fastcgi_temp/5/02/0000000025" failed (13: Permission denied) 
while reading upstream, client: 203.171.237.2, server: internal.xxx.com, request: "GET /xxx/xxx
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值