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

本文详细介绍php-fpm的配置方法,包括如何为不同站点设置独立的pool,以避免单点故障;配置open_basedir限制站点访问路径;调整pm参数进行性能优化;以及启用慢查询日志等。

#php-fpm的poo ###作用 避免因多站点使用同一个pool时因一个站点故障导致pool出问题,进而影响使用同一个pool的其他站点的正常运行,要对每个站点配置一个单独的poo ###编辑配置文件

vim /usr/local/php-fpm/etc/php-fpm.conf  
[test.com]
listen = /tmp/test.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

###检测重新加载

/usr/local/php-fpm/sbin/php-fpm -t
[16-Aug-2017 16:10:23] NOTICE: configuration file /usr/local/php-fpm/etc/php-fpm.conf test is successful
/etc/init.d/php-fpm reload
Reload service php-fpm  done

###修改虚拟主机配置文件

vim /usr/local/nginx/conf/vhost/aaa.com.conf

location ~ \.php$
    {
        include fastcgi_params;
        fastcgi_pass unix:/tmp/test.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME /data/wwwroot/default$fastcgi_script_name;
    }
#######把fastcgi_pass地址改为和php-fpm.conf中一样的地址。

###增加全局

vim /usr/local/php-fpm/etc/php-fpm.conf

[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
include = etc/php-fpm.d/*.conf

###创建php-fpm子配置文件

####创建指定目录:

cd /usr/local/php-fpm/etc/ 
mkdir php-fpm.d&&cd php-fpm.d/

####创建php-fpm子配置文件:

vim www.conf
[www]
listen = /tmp/php-fcgi.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

[root@adailinux php-fpm.d]# vim adai.conf
[adai.com]
listen = /tmp/adai.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

####检查重新加载:

/usr/local/php-fpm/sbin/php-fpm -t
configuration file /usr/local/php-fpm/etc/php-fpm.conf test is successful
/etc/init.d/php-fpm reload
Reload service php-fpm  done

#慢执行日志 ###开启慢执行日志:

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

###检查重启

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

###虚拟主机测试 ####创建一个.php文件

[root@adailinux php-fpm.d]# vim /data/wwwroot/test.com/sleep.php
<?php
echo "test slow log";
sleep(2);
echo "done";
?>

####检测:

[root@adailinux php-fpm.d]# curl -x127.0.0.1:80 test.com/sleep.php 
test slow logdone

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

###核心配置参数:

vim /usr/local/php-fpm/etc/php-fpm.d/www.conf  
php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp/

###创建测试PHP脚本:

[root@adailinux php-fpm.d]# vim /data/wwwroot/test.com/1.php
<?php
echo "This is a test php of open_basedir";
###测试
curl -x127.0.0.1:80 test.com/1.php
This is a test php of open_basedir

#进程管理 ###php-fpm中pool参数详解

vim www.conf
[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
;定义进程启动方式(dynamic表示动态,static表示静态)
;只有此处设置为dynamic,下面的配置才生效
pm.max_children = 50
;最多可启动的子进程数量
pm.start_servers = 20
;设定初始启动的进程数量
pm.min_spare_servers = 5
;表示php-fpm空闲时最少要有几个子进程
pm.max_spare_servers = 35
;表示php-fpm空闲时最多要有几个子进程
pm.max_requests = 500
;表示一个子进程最多可接受多少个请求
rlimit_files = 1024
;表示每个子进程打开的多少个文件句柄
request_slowlog_timeout = 1
;当请求超过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/jiangshanlinux/blog/1511680

在Linux系统下,php - fpm.service因PHP报错关闭所有进程可能有以下原因及相应解决办法: ### 原因一:无法创建PID文件 报错信息如 “ERROR:Unable to create the PID file (/usr/local/php/var/run/php-fpm.pid).: Read-only file system ERROR: FPM initialization failed”,这是因为没有权限创建php - fpm.pid文件,导致启动不起来。深层原因可能与系统服务配置有关,如ProtectSystem=full配置限制了文件创建权限[^3]。 解决办法:在编译安装php的时候,进入系统服务配置目录`cd /usr/lib/systemd/system/`,编辑`php - fpm.service`文件,找到`ProtectSystem=full`一行,在前面加`#`注释掉。修改系统服务后需要执行`systemctl daemon - reload` ,之后重启php - fpm即可。不过需注意,注释掉这一行可能存在被攻击的风险[^3]。 ### 原因二:找不到用户UID 报错信息 “ERROR: [pool www] cannot get uid for user 'nginx'” 表明,在centos7系统中,php - fpm无法获取指定用户(如nginx)的UID,从而导致初始化失败,关闭所有进程[^4]。 解决办法:检查系统中是否存在指定用户(如nginx),若不存在则创建该用户。可通过以下命令创建用户: ```bash useradd nginx ``` ### 原因三:文件路径限制 在Ubuntu系统运行PHP项目时,可能出现 “Warning: require_once(): open_basedir restriction in effect. File(... ) is not within the allowed path(s): (...)” 这类错误。这是由于`open_basedir`配置限制了PHP脚本可以访问的文件路径,当PHP脚本尝试访问不在允许路径内的文件时,就会报错并可能导致进程关闭[^5]。 解决办法:修改PHP配置文件(通常是`php.ini`),调整`open_basedir`的值,将需要访问的文件路径添加进去。例如: ```ini open_basedir = "/home/wwwroot/jkpt/user/public:/tmp/:/proc/:/home/wwwroot/jkpt/doitphp/" ``` 修改后重启php - fpm服务。 ### 原因四:控制进程退出错误 报错信息 “Job for php - fpm.service failed because the control process exited with error code” 显示,控制进程以错误代码退出,可能是执行文件路径错误或文件本身有问题等原因导致[^1]。 解决办法:检查`php - fpm.service`文件中`ExecStart`等配置项的路径是否正确,确保执行文件存在且有执行权限。例如检查`ExecStart=/usr/local/php/sbin/php - fpm`中的文件是否存在。若不存在,需要重新安装或调整路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值