您的位置:首页 > 编程语言 > PHP开发

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

2018-08-19 22:32 966 查看

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/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Vim php-fpm
相关文章推荐