wsl搭建php环境请求超时的问题解决方案

一、出现问题

今天在公司电脑安装了wsl,在部署php环境的时候发现由nginx转发到php-fpm的请求非常慢,查看nginx错误日志显示

[error] 3383#3383: *74 upstream timed out (110: Connection timed out) while reading upstream, client: 127.0.0.1, server: demo, request: "POST /pms/login HTTP/1.1", upstream: "fastcgi://
    unix:/var/run/php/php7.2-fpm.sock:", host: "demo"

nginx和fastcgi的通信方式有两种,一种是TCP socket的方式,一种是unix socket方式,因为wsl安装的php-fpm默认是unix socket,我就没改动了 1.TCP是使用TCP端口连接127.0.0.1:9000

 fastcgi_pass 127.0.0.1:9000;

2.Socket是使用unix domain socket连接套接字php-fpm.sock

 fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;

二、两种通信方式的分析和总结

从原理上来说,unix socket方式肯定要比tcp的方式快而且消耗资源少,因为socket之间在nginx和php-fpm的进程之间通信,而tcp需要经过本地回环驱动,还要申请临时端口和tcp相关资源。 当然还是从原理上来说,unix socket会显得不是那么稳定,当并发连接数爆发时,会产生大量的长时缓存,在没有面向连接协议支撑的情况下,大数据包很有可能就直接出错并不会返回异常。而TCP这样的面向连接的协议,多少可以保证通信的正确性和完整性。 因为我是作为开发环境使用,所以直接用unix socket,而服务器上用tcp,用于负载均衡。

三、解决方案

在nginx的配置文件中加入

 fastcgi_buffering off;

这个配置是否启用读取fastcgi服务器消息的缓冲功能。 如果配置为on,nginx在接收到fastcgi服务器的响应结果时尽快将响应写到缓冲区(由fastcgi_buffer_size和fastcgi_buffering指令控制)中,如果响应结果超过了缓冲区的大小,nginx会将超出部分写到临时文件(由fastcgi_max_temp_file_size和fastcgi_temp_file_write_size指令控制)中。 如果配置为off,nginx在接收到fastcgi服务器的响应结果时,会将结果同步发送给客户端,不等到所有的响应结果接收完成时,一次性读取响应结果的最大值为fastcgi_buffer_size配置的大小

欢迎扫描下方二维码,持续关注:

互联网工程师(id:phpstcn),我们一起学习,一起进步

转载于:https://my.oschina.net/xushuhui/blog/2999595

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值