要提升 CentOS 中 PHP-FPM 的并发能力,可以通过以下方法进行优化:
修改配置文件:
打开 PHP-FPM 配置文件,通常位于 /etc/php-fpm.d/www.conf 或 /etc/php-fpm.conf。修改以下参数:
pm:设置为 dynamic 或 ondemand,以便根据负载自动调整子进程数量。pm.max_children:设置最大子进程数。根据服务器的内存和应用程序的需求进行调整。pm.start_servers:设置启动时的子进程数量。建议设置为可用 CPU 核心数的 4 倍。pm.min_spare_servers 和 pm.max_spare_servers:设置空闲子进程的最小和最大数量。根据服务器的负载进行调整。例如:
pm = dynamic
pm.max_children = 50
pm.start_servers = 8
pm.min_spare_servers = 4
pm.max_spare_servers = 16
调整 PHP 脚本执行时间:
如果你的 PHP 脚本需要较长时间才能执行完成,可以考虑增加 PHP 脚本的最大执行时间。编辑 php.ini 文件(通常位于 /etc/php.ini),修改 max_execution_time 参数。
例如:
max_execution_time = 300
优化数据库连接:
如果你的应用程序使用数据库,确保使用持久连接(persistent connection)以减少连接开销。在 PHP 代码中,可以使用 p: 前缀的 DSN(Data Source Name)来创建持久连接。
例如:
$dsn = 'mysql:host=localhost;dbname=mydb;charset=utf8mb4';
$user = 'username';
$password = 'password';
$options = [
PDO::ATTR_PERSISTENT => true,
];
$pdo = new PDO($dsn, $user, $password, $options);
使用 OpCode 缓存:
使用 OpCode 缓存(如 OPcache)可以减少 PHP 脚本的编译时间,从而提高性能。确保已安装并启用了 OPcache 扩展。你可以在 php.ini 文件中启用它:
zend_extension=opcache.so
opcache.enable=1
opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=4000
使用负载均衡: 如果你的应用程序需要处理大量请求,可以考虑使用负载均衡(如 Nginx 或 HAProxy)将请求分发到多个 PHP-FPM 实例。
通过以上方法,你可以提高 CentOS 中 PHP-FPM 的并发能力。请根据实际情况调整参数,并在修改配置文件后重启 PHP-FPM 服务以使更改生效。