php-fpm的pool - 慢执行日志 - 进程管理 - open_basedir

本文介绍了php-fpm的配置方法,包括如何为不同站点设置独立的pool来提高稳定性,如何开启慢执行日志以便诊断性能瓶颈,以及如何通过open_basedir限制站点访问范围等高级配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

php-fpm的pool :

为避免多站点使用同一个pool时因一个站点故障导致php资源耗尽,牵连使用同一个pool的其他站点的正常工作,可对每一个站点设置独立pool。

增加pool:

1.编辑php-fpm配置文件:

vim /usr/local/php-fpm/etc/php-fpm.conf              #在[global]部分内添加以下内容:

[zjy.com]                          #pool名字
listen = /tmp/zjy.sock             #监听sock文件
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024

2.检测并重新加载配置:

/usr/local/php-fpm/sbin/php-fpm -t;/etc/init.d/php-fpm reload

3.检查是否配置成功:

ps aux |grep php-fpm                   #查看最右侧是否出现 pool zjy.com 的进程

 

站点分配pool:

1.编辑虚拟主机配置文件:

vim /usr/local/nginx/conf/vhost/aaa.com.conf           #在server{}内添加以下内容:

location ~ \.php$
    {
        include fastcgi_params;
        fastcgi_pass unix:/tmp/zjy.sock;                  #更改对应pool的sock文件路径
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME /data/wwwroot/default$fastcgi_script_name;
    }

 

为使php-fpm配置文件更简洁,可以把配置文件中的所有pool配置拆离出来放到独立的文件中,操作如下:

1.编辑php-fpm配置文件:

vim /usr/local/php-fpm/etc/php-fpm.conf              #在[global]部分内添加以下内容:

include = etc/php-fpm.d/*.conf

并将该文件中的每组pool配置拷贝并删除。

2.创建上一步include字段对应目录和所有pool配置对应的conf文件:

mkdir -p /etc/php-fpm/etc/;touch www.conf;touch zjy.conf

3.把第一步拷贝的pool配置粘贴到对应conf配置中。

4.检测并重新加载配置:

/usr/local/php-fpm/sbin/php-fpm -t;/etc/init.d/php-fpm reload

 

php-fpm的慢执行日志:

可根据该日志分析php网站运行过慢的原因。

打开慢执行日志:

1.编辑站点配置文件:

vim /usr/local/php-fpm/etc/php-fpm.d/www.conf   #添加以下内容,注意此www.conf配置中的sock文件被哪个站点所用。后续第三步有用到

request_slowlog_timeout = 1                             #当请求超过1秒开始记录日志
slowlog = /usr/local/php-fpm/var/log/www-slow.log       #日志存放地址

2.检测并重新加载配置:

/usr/local/php-fpm/sbin/php-fpm -t;/etc/init.d/php-fpm reload

3.创建测试php文件,在使用www.conf的pool的站点的路径下创建:

vim /data/wwwroot/test.com/sleep.php                 #添加以下内容:

<?php
echo "test slow log";
sleep(2);                            #休眠2秒
echo "done";
?>

4.测试:

执行:curl -x127.0.0.1:80 test.com/sleep.php 

# curl -x127.0.0.1:80 test.com/sleep.php 
test slow logdone

同时查看慢执行日志:

执行:tailf /usr/local/php-fpm/var/log/www-slow.log 

# tailf /usr/local/php-fpm/var/log/www-slow.log 

[16-Aug-2017 17:14:55]  [pool www] pid 6451
script_filename = /data/wwwroot/test.com/sleep.php               #日志显示这个php脚本运行慢
[0x00007fe02560e2e0] sleep() /data/wwwroot/test.com/sleep.php:3  #具体运行慢的地上在这个脚本的第三行

 

php-fpm中指定open_basedir:

当一台服务器跑多个站点时,使用open_basedir限定每个站点所能访问的服务器上的目录的范围。在php-fpm服务中,可以针对每个pool设定open _ basedir。

1.编辑站点配置文件:

vim /usr/local/php-fpm/etc/php-fpm.d/www.conf            #添加以下内容:

php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp/

2.检测并重新加载配置:

/usr/local/php-fpm/sbin/php-fpm -t;/etc/init.d/php-fpm reload

3.创建测试php文件:

vim /data/wwwroot/test.com/1.php        #添加以下内容:

<?php
echo "This is a test php of open_basedir";

4.测试:

执行:curl -x127.0.0.1:80 test.com/1.php

# curl -x127.0.0.1:80 test.com/1.php
This is a test php of open_basedir

 

php-fpm进程管理:

/usr/local/php-fpm/etc/php-fpm.d/www.conf配置参数解析:

[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
;定义进程启动方式(dynamic动态,static静态)    #此配置使用;进行注释
;当设置为dynamic,下面配置才生效
pm = dynamic
;最多可启动的子进程数量
pm.max_children = 50
;设定初始启动的进程数量
pm.start_servers = 20
;表示php-fpm空闲时最少要有几个子进程
pm.min_spare_servers = 5
;表示php-fpm空闲时最多要有几个子进程
pm.max_spare_servers = 35
;表示一个子进程最多可接受多少个请求
pm.max_requests = 500
;表示每个子进程打开的多少个文件句柄
rlimit_files = 1024
;当请求超过1秒开始记录日志
request_slowlog_timeout = 1
;日志存放地址
slowlog = /usr/local/php-fpm/var/log/www-slow.log

php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp/

 

转载于:https://my.oschina.net/u/3866910/blog/1930467

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值