php-fpm相关操作
php-fpm常用操作
一.
php5.3.3之后使用新号方式控制php-fpm进程 INT, TERM 立即终止 QUIT 平滑终止 USR1 重新打开日志文件 USR2 平滑重启所有worker进程并重新载入配置和二进制模块
操作:
# 平滑重启 kill -USR2 16550
kill -USR2 `cat /usr/local/var/run/php-fpm.pid`
# 启动
/etc/init.d/php-fpm start
使用php-fpm.pid进行关闭与重启操作:
1. 修改配置
vim php-fpm.conf [global] ; Pid file ; Note: the default prefix is /opt/apps/var ; Default Value: none pid = run/php-fpm.pid
2. 重启php-fpm即可生成php-fpm.pid
kill -USR2 10857 php-fpm 关闭: kill -INT `cat /usr/work/tool/php/var/run/php-fpm.pid`
php-fpm 重启: kill -USR2 `cat /usr/work/local/php/var/run/php-fpm.pid`
3. 启动指定配置文件
./php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf -c 指定php.ini配置文件 -y 指定php-fpm.conf配置文件
4.校验配置
/usr/local/php/sbin/php-fpm -t
5.开启慢日志
request_slowlog_timeout = 3s slowlog = var/log/slow.log
日志内容:
[14-Oct-2024 14:23:22] [pool www] pid 204029 script_filename = /mnt/e/www/api/public/index.php [0x00007f95cda142b0] sleep() /mnt/e/www/api/application/controllers/Api.php:66 [0x00007f95cda14240] testAction() /mnt/e/www/api/public/index.php:16 [0x00007f95cda141f0] run() /mnt/e/www/api/public/index.php:16
php-fpm.conf配置项:
;request_terminate_timeout 将执行时间太长的进程直接终止
request_terminate_timeout=10s
完整配置:
[global] pid = /usr/local/php/var/run/php-fpm.pid error_log = /usr/local/php/var/log/php-fpm.log log_level = notice [www] listen = /tmp/php-cgi.sock ;listen = 127.0.0.1:9000 listen.backlog = -1 listen.allowed_clients = 127.0.0.1 listen.owner = www listen.group = www listen.mode = 0666 user = www group = www pm = dynamic pm.max_children = 200 pm.start_servers = 30 pm.min_spare_servers = 30 pm.max_spare_servers = 60 pm.max_requests = 1024 pm.process_idle_timeout = 10s request_terminate_timeout = 100 ;request_slowlog_timeout = 0 request_slowlog_timeout = 1s slowlog = var/log/slow.log access.log = var/log/$pool.access.log access.format = "%R - %u %t \"%m %r%Q%q\" %s %f %{mili}d %{kilo}M %C%%"
sock VS tcp
php-fpm提供了两种方式提供服务
从上面的图片可以看,unix socket减少了不必要的tcp开销,而tcp需要经过loopback,还要申请临时端口和tcp相关资源。但是,unix socket高并发时候不稳定,连接数爆发时,会产生大量的长时缓存,在没有面向连接协议的支撑下,大数据包可能会直接出错不返回异常。tcp这样的面向连接的协议,多少可以保证通信的正确性和完整性。
tcp socket)
允许通过网络进程之间的通信,也可以通过loopback进行本地进程之间通信。
unix socket)
1)允许在本地运行的进程之间进行通信。
2)将sock文件放在/dev/shm目录下,使用的内存读写更快。
# cd /dev/shm touch php7.0-fpm.sock chown www-data:www-data php7.0-fpm.sock chmod 777 php7.0-fpm.sock
php-fpm配置:
# vi /etc/php/7.0/fpm/pool.d/www.conf listen= /dev/shm/php7.0-fpm.sock listen.owner = www-data listen.group = www-data
nginx配置:
location ~* \.php$ { fastcgi_pass unix:/dev/shm/php7.0-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include /etc/nginx/fastcgi_params; }
3)提升稳定性
1.修改内核参数 /etc/sysctl.conf net.unix.max_dgram_qlen = 4096 net.core.netdev_max_backlog = 4096 net.core.somaxconn = 4096
2.提高backlog
backlog默认位128,1024这个值最好换算成自己正常的QPS。
nginx.conf server{ listen 80 default backlog=1024; } php-fpm.conf listen.backlog = 1024
3.增加sock文件和php-fpm实例
在/dev/shm新建一个sock文件,在nginx中通过upstream魔抗将请求负载均衡到两个sock文件,
并且将两个sock文件分别对应到两套php-fpm实例上。
如果是在同一台服务器上运行的nginx和php-fpm,并发量不超过1000,选择unix socket,因为是本地,可以避免一些检查操作(路由等),因此更快,更轻。
如果我面临高并发业务,我会选择使用更可靠的tcp socket,以负载均衡、内核优化等运维手段维持效率。
有关backlog:
有高并发的业务,就必须要调整backlog。对于PHP而言,需要注意的有3方面:
1、操作系统 | sysctl
2、WEB前端 | 比如:Nginx
3、PHP后台 | 比如:php-fpm
操作系统以CentOS为例,可通过默认配置 /etc/sysctl.conf 文件进行调整。比如:
net.core.somaxconn = 1048576 # 默认为128
net.core.netdev_max_backlog = 1048576 # 默认为1000
net.ipv4.tcp_max_syn_backlog = 1048576 # 默认为1024
WEB前端以Nginx为例,可通过默认配置 /etc/nginx/nginx.conf 文件中的监听选项来调整。比如:
listen 80 backlog=8192; # 默认为511
PHP后台,以PHP-FPM为例,可以通过默认配置 /etc/php-fpm.d/www.conf 文件进行调整。比如:
listen.backlog = 8192 # 默认为-1(由系统决定)
大系统下,如上3处都应该进行调整。
值得注意的是:
PHP-FPM的配置文件中,关于listen.backlog选项的注释有些误导人:
; Set listen(2) backlog. A value of '-1' means unlimited.
; Default Value: -1
实际上如果使用默认值,很容易出现后端无法连接的问题,按老文档上的解释这个默认是200。建议此处不要留空,务必设置一个合适的值。