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/
相关文章推荐
- php-fpm的pool php-fpm慢执行日志 open_basedir php-fpm进程管理
- php-fpm的pool、慢执行日志、进程管理、open_basedir
- php-fpm的pool, php-fpm慢执行日志,open_basedir,php-fpm进程管理
- LNMP(php-fpm的pool,慢执行日志,定义open_bashdir,php-fpm进程管理
- linux学习第四十八篇:php-fpm的pool,php-fpm慢执行日志,定义open_basedir,php-fpm进程管理
- linux的php-fpm的pool、慢执行日志、进程管理及open_basedir介绍
- php-fpm的pool、PHP慢执行日志、open_basedir、php-fpm进程管理
- LNMP架构 (6) 之 php-fpm的pool、慢执行日志、open_basedir、进程管理
- 【LNMP】php-fpm的pool、php-fpm慢执行日志、php-fpm定义open_basedir和php-fpm进程管理
- 12.21 php-fpm的pool12.22 php-fpm慢执行日志 12.23 open_basedir 12.24 php-fpm进程管理
- php-fpm的pool、PHP慢执行日志、open_basedir、php-fpm进程管理
- php-fpm的pool、php-fpm慢执行日志、open_basedir、php-fpm进程管理
- php-fpm的pool,php-fpm慢执行日志,open_basedir,php-fpm进程管理
- php-fpm的pool、慢执行日志、 open_basedir、 进程管理
- php-fpm的pool、慢执行日志、open_basedir、进程管理
- php-fpm的pool、PHP慢执行日志、open_basedir、php-fpm进程管理
- nginx代理,负载均衡,ssl,php-fpm的pool,慢执行日志,open_basedir,php-fpm进程管理
- 51.php-fpm的pool 慢日志 open_basedir 进程管理
- LNMP架构(六)之php-fpm,慢执行日志,open_basedir,php-fpm进程管理