Linux系统上目前主要使用Apache和php-fpm来解析运行PHP Web程序。php-fpm仅支持多进程,Apache支持多进程和多线程,但绝大多数环境中均为多进程方式,这里也只讨论多进程。

从实践来看,单实例最多可以开到200-300左右的进程,开到500以上就容易出错了。

每个进程占用的内存在5M-15M左右,按平均10M计算,500个进程也只有5G,而现在很多高性能机都是64G甚至128G的内存,这样单实例是无法全面使用上内存资源的。
这几年部署过的多实例环境并不多,因为访问量不是十分高的话,是用不上的。
上次配置多实例是一个100万左右PV的Discuz论坛,配置之后是很有效的。现在做的这个是千万PV的静态站,请求主要在点击计数上,在300和500之间调整进程数还是会偶尔的挂掉,机器配置是足够用的,是稳定性的问题。

LNMP或者LNAMP环境的配置这里不做介绍,只讲在LNMP环境的基础上配置多实例的过程。因为我在使用的是LNAMP环境,所以额外编译一份php到/usr/local/php-fpm/,配置文件在/etc/php-fpm/,并在此基础上做的笔记。

先修改三个值:

1,以static方式,也就是固定进程数量运行php-fpm。
2,每个实例建立100个worker进程。(不宜太多,避免不稳定)
3,每个进程执行完200次请求即退出。(避免PHP的内存泄露问题,也就是内存越用越多)

sed -i 's#pm = dynamic#pm = static#' /etc/php-fpm/php-fpm.conf

sed -i 's#pm.max_children = 5#pm.max_children = 100#' /etc/php-fpm/php-fpm.conf
sed -i 's#;pm.max_requests = 500#pm.max_requests = 200#' /etc/php-fpm/php-fpm.conf

以下为复制php-fpm.conf和php-fpm服务管理脚本的命令

cd /etc/php-fpm/

cp php-fpm.conf  php-fpm-1.conf
sed -i 's#listen = 127.0.0.1:9000#listen = 127.0.0.1:9001#' php-fpm-1.conf
sed -i 's#\[www\]#\[php-fpm-pool-1\]#' php-fpm-1.conf
sed -i 's#pid = run/php-fpm.pid#pid = run/php-fpm-1.pid#' php-fpm-1.conf
cd /etc/init.d/
cp php-fpm  php-fpm-1
sed -i 's#/etc/php-fpm/php-fpm.conf#/etc/php-fpm/php-fpm-1.conf#' php-fpm-1
sed -i 's#/var/run/php-fpm.pid#/var/run/php-fpm-1.pid#' php-fpm-1
service php-fpm-1 restart

执行完上面的命令即复制了一份php-fpm,服务名和配置文件名均为php-fpm-1。

再复制更多份,把上面的命令上的-1替换为-2,listen监听端口往上修改,然后再执行一遍就OK。

然后写一个restart_php_fpm.sh的文件,内容为

service php-fpm-1 restart

service php-fpm-2 restart
service php-fpm-3 restart
... ...

可以用来启动和重启所有的php-fpm实例。关闭用命令killall php-fpm即可。

然后是Nginx配置。

在http段加入:

upstream php-fpm-pool {  

    server 127.0.0.1:9001;
    server 127.0.0.1:9002;
    server 127.0.0.1:9003;
    server 127.0.0.1:9004;
    server 127.0.0.1:9005;
}

修改server段:

location ~ .*\.(php|php5)?$ {

    fastcgi_pass php-fpm-pool;
    fastcgi_index index.php;
    include fastcgi.conf;
}

配置结束。

多实例在效果上基本等于多台机器的负载均衡,但是我个人还是比较倾向于在单台上配置多实例(累加资源相等的情况下),在一台机器上配置、维护、使用都要方便的多