调整调整backlog配置,解决nginx日志报错php-pool/php-fpm.sock failed (...) while connecting to upstream

nginx日志报错:

connect() to unix:/home/data/mystack/sites/www.888.com/php-pool/php-fpm.sock failed (11: Resource temporarily unavailable) while connecting to upstream

在appnode上的调整backlog配置方法

1、修改内核,在/etc/sysctl.conf中添加
net.ipv4.tcp_max_syn_backlog = 4096
net.core.netdev_max_backlog = 4096

2、php-fpm配置修改
/data/mystack/sites/www.888.com/conf/php-1.conf
把listen.backlog = -1修改成listen.backlog = 4096
不知为何重启后又变回-1了
其他方法:在/etc/opt/appnode/scls/appnode-php72/php-fpm.d/www.conf中直接修改listen.backlog的值,默认是511

3、nginx配置修改
/data/mystack/sites/www.888.com/conf/nginx.conf
把listen 80;修改成listen 80 default backlog=4096;

最后重启php、nginx即可

当然,适当提高pm.max_children、pm.max_spare_servers
注意:pm.start_servers<=pm.min_spare_servers<pm.max_spare_servers<=pm.max_children

例如设置为
pm.max_children = 50
pm.start_servers = 10
pm.min_spare_servers = 10
pm.max_spare_servers = 50
参考https://www.centos.bz/2018/01/php-fpm优化方法-pm-min_spare_servers、pm-max_spare_servers/

-----------------------------------------------------------

别人给的方法

nginx + php做服务,在高并发的时候会出现一些错误  connect() to unix:/var/run/php-fpm.sock failed (11: Resource temporarily unavailable)  。

目前有两种方法可以试试。

  环境: ubuntu + nginx + php7.1

 

一、修改参数:

  1、内核修改

sudo vim /etc/sysctl.conf

net.ipv4.tcp_max_syn_backlog = 4096
net.core.netdev_max_backlog = 4096

重新启动
sudo reboot

  2、php-fpm配置修改

修改  /etc/php/7.1/fpm/pool.d/www.conf
(在app的路径:data/mystack/php-pools/_dummy/php-1.cofig)

listen.backlog = 4096

  sudo service php-fpm7.1 restart

 

  3、nginx配置修改

 

listen 80 default backlog=4096;

重新启动
sudo service nginx restart

 

 

二、添加php-fpm的master实例,会增加fpm的处理能力,也能减少报错的机率

 

  1、拷贝php配置文件

cd  /etc/php/7.1/fpm/   
sudo cp php-fpm.conf  php-fpm2.conf


cd pool.d
sudo cp www.conf www2.conf

  2、修改php的配置文件

sudo  vim  php-fpm2.conf

修改内容
pid = /run/php/php7.1-fpm2.pid
error_log = /var/log/php7.1-fpm2.log

include=/etc/php/7.1/fpm/pool.d/www2.conf

  3、重新启动

sudo /usr/sbin/php-fpm7.1 -y /etc/php/7.1/fpm/php-fpm2.conf

  查看    ps -ef | grep php

  或者进入  cd  /var/run/php  查看

 

关闭和重启

sudo  pkill  php-fpm
(关闭所有的php进程)

启动php1       sudo service php7.1-fpm restart
启动php2       sudo /usr/sbin/php-fpm7.1 -y /etc/php/7.1/fpm/php-fpm2.conf

 

  4、nginx配置,在 nginx.conf中添加

  upstream php-socks {
                server unix:/run/php/php7.1-fpm.sock;
                server unix:/run/php/php7.1-fpm2.sock;
        }

      在 *.conf的server中添加

fastcgi_pass  php-socks;   # unix:/run/php/php7.1-fpm.sock;

      重新启动

sudo service nginx restart

  参考:
https://www.cnblogs.com/cj8988/p/9475564.html
https://my.oschina.net/kisops/blog/151079

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章