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