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