配置还是非常简单的,充分体现了nginx的强大与配置的简单^^下面是大致的服务器结构图:
应用的最前端是一台nginx服务器,所有静态的内容都由nginx来处理,而将所有php的请求都分摊到下游的若干台运行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这台服务器为例:
1
|
/usr/local/php5/bin/php-cgi -b 172.16.236.110:9000
|
或许你用spawn-fcgi来启动php-fcgi,那么就是这样(供参考,其实也就是修改监听的地址和端口即可):
1
|
/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的配置:
1
|
vi /usr/local/php5/etc/php-fpm.conf
|
找到这个配置项(其中的地址可能需要根据你自己环境来调整)
1
|
<value name="listen_address">127.0.0.1:9000</value>
|
修改为:
1
|
<value name="listen_address">172.16.236.110:9000</value>
|
修改完毕后,重启你的php-fpm进程。
然后按照上面的步骤,依次修改其他php fastcgi服务器。
php方面的工作暂时就是这些,下面修改nginx。
1
|
vi /usr/local/nginx/conf/nginx.conf
|
在配置文件的http段内增加类似如下的配置:
1
2
3
4
5
|
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值来达到目的。比如以第一台服务器为主,其他两台为辅,则就是这样:
1
2
3
4
5
|
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配置的部分,比如:
1
2
3
4
5
6
|
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
|
将其中的fastcgi_pass那一段改为:
1
|
fastcgi_pass myfastcgi;
|
其中的myfastcgi也就是上面刚刚配置的php fastcgi均衡器的名字了。
完了以后,重启nginx即可。
简单吧,就通过这么几个简单的配置,就可以实现一个经济高效的nginx、多php-fcgi的负载均衡解决方案了。当然了,这样的方案运用到实际项目中还需要进行一些细化的配置,主要是php方面还需要进一步配置,我会在接下来的博客中记录现在项目的一些心得。
分享到:
相关推荐
nginx配置 +负载均衡+https协议 完整的配置以及nginx 启动 停止 重新加载
nginx配置多台tomcat做负载均衡.docx
使用nginx+eureka实现微服务的高负载均衡,提高网站的访问性能
基于lua的nginx自定义负载均衡基于lua的nginx自定义负载均衡
nginx和tomcat配置SSL和负载均衡配置,
Keepalived + Nginx 实现高可用 Web 负载均衡配置文件,具体详情参见博文:http://blog.csdn.net/l1028386804/article/details/72801492
nginx经常用到的负载均衡的5种策略,注意细节,部分属性不能一起使用。
Nginx+Tomcat配置3台负载均衡及https
对于数据流量过大的网络中,往往单一设备无法承担,需要多台设备进行数据分流,而负载均衡器是用来将数据分流到多台设备的一个转发器。 目前有许多不同的负载均衡技术用以满足不同的应用需求,如软/硬件负载均衡...
nginx安装、配置、负载均衡
nginx配置优化+负载均衡+动静分离详解
Nginx+tomcat配置集群负载均衡实现动静分离实例
Tomcat在高并发环境下处理动态请求时性能很低,而在处理静态页面更加脆弱。是通过Nginx来处理静态页面要比通过Tomcat处理在性能方面好很多。本例为nginx负载均衡配置方法
在Linux下安装、配置nginx,配置双tomcat实现负载均衡
Nginx下实现对cxf WebService的负载均衡。
Nginx配置多个service 多个访问路径 找到conf/nginx.conf修改配置文件 #user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid ...
nginx+redis负载均衡、session共享,基于redis+tomcat实现session同步的简单demo
FreeBSD 8.1下用nginx配置简单web负载均衡
Nginx和tomcat配置负载均衡集群,互相学习哈,给大家参考,有问题可以做修改
nginx+tomcat配置实现负载均衡,亲测可用