調整調整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

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