配置还是非常简单的,充分体现了的强大与配置的简单 ^^ 下面是大致的服务器结构图:
应用的最前端是一台 nginx 服务器,所有静态的内容都由 nginx 来处理,而将所有的 请求都分摊到下游的若干台
运行 php fastcgi 守护进程的服务器中,这样可以以一种廉价的方案来实现对系统负载的分摊,扩展系统的负载能力.
三台 php-fastcgi 服务器的 ip 地址分别为:
172.16.236.110 , 172.16.236.111, 172.16.236.112
运行 php-fastcgi 进程时,需要让 php-cgi 监听到服务器的局域网地址(分别如上所示),而不是之前一般都是监听的
本地地址(127.0.0.1).
以 172.16.236.110 这台服务器为例:
/usr/local / php5 / bin / php - cgi - b 172.16.236.110 : 9000
或许你用 spawn-fcgi 来启动 php-fcgi,那么就是这样(供参考,其实也就是修改监听的地址和端口即可):
/usr/local / lighttpd / bin / spawn - fcgi - f / usr / local / php5 / bin / php - cgi - a 172.16.236.110 - p 9000
又或许你是用 php-fpm 来管理 php-fcgi,那么你需要修改 php-fpm 的配置:
vim / usr / local / php5 / etc / php - fpm.conf
找到这个配置项(其中的地址可能需要根据你自己环境来调整)
name="listen_address">127.0.0.1:9000>
修改为:
name="listen_address">172.16.236.110:9000> 修改完毕后,重启你的 php-fpm 进程.
然后按照上面的步骤,依次修改其他 php fastcgi 服务器.
php 方面的工作暂时就是这些,下面修改 nginx.
vim / usr / local / nginx / conf / nginx.conf
在配置文件的 http 段内增加类似如下的配置:
upstream myfastcgi {
server 172.16.236.110 weight = 1;
server 172.16.236.111 weight = 1;
server 172.16.236.112 weight = 1;
}
我这里三台 php fastcgi 服务器的权重是相同的,所以其中的 weight 值都是 1,如果你的 php fastcgi 服务器需要分主次,那么
可以通过调整其 weight 值来达到目的.比如以第一台服务器为主,其他两台为辅,则就是这样:
upstream myfastcgi {
server 172.16.236.110 weight = 1;
server 172.16.236.111 weight = 2;
server 172.16.236.112 weight = 2;
}
然后找到原来 nginx 关于 php fastcgi 配置的部分,比如:
location~\.php$ {
fastcgi_pass 127.0.0.1 : 9000;
fastcgi_index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
将其中的 fastcgi_pass 那一段改为:
fastcgi_pass myfastcgi;
其中的 myfastcgi 也就是上面刚刚配置的 php fastcgi 均衡器的名字了.
完了以后,重启 nginx 即可.
简单吧,就通过这么几个简单的配置,就可以实现一个经济高效的 nginx,多 php-fcgi 的负载均衡解决方案了.
当然了,这样的方案运用到实际项目中 还需要进行一些细化的配置,主要是 php 方面还需要进一步配置,
我会在接下来的博客中记录现在项目的一些心得.
来源: http://lib.csdn.net/article/php/36307