配置还是非常简单的,充分体现了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这台服务器为例:
或许你用spawn-fcgi来启动php-fcgi,那么就是这样(供参考,其实也就是修改监听的地址和端口即可):
又或许你是用php-fpm来管理php-fcgi,那么你需要修改php-fpm的配置:
找到这个配置项(其中的地址可能需要根据你自己环境来调整)
修改为:
修改完毕后,重启你的php-fpm进程。 然后按照上面的步骤,依次修改其他php fastcgi服务器。 php方面的工作暂时就是这些,下面修改nginx。
在配置文件的http段内增加类似如下的配置:
我这里三台php fastcgi服务器的权重是相同的,所以其中的weight值都是1,如果你的php fastcgi服务器需要分主次,那么可以通过调整其weight值来达到目的。比如以第一台服务器为主,其他两台为辅,则就是这样:
然后找到原来nginx关于php fastcgi配置的部分,比如: 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那一段改为:
其中的myfastcgi也就是上面刚刚配置的php fastcgi均衡器的名字了。 完了以后,重启nginx即可。 简单吧,就通过这么几个简单的配置,就可以实现一个经济高效的nginx、多php-fcgi的负载均衡解决方案了。当然了,这样的方案运用到实际项目中还需要进行一些细化的配置,主要是php方面还需要进一步配置。 |
涉及的session同步如何处理?
在需要用到php-fastcgi做负载均衡的情景下的话,应用应该挺大的了。一般来说可以不用session或采用自建session。如果实在要实现session的话,可以把这几台php fastcgi服务器的session统一存到一台memcached中,这样就实现了session的同步了