版权声明:此文章转载自迹忆
原文地址: http://www.onmpw.com/tm/xwzj/network_144.html
如需转载请联系听云college团队成员阮小乙,邮箱:ruanqy#tingyun.com
集群的概念没有多复杂,其实就是多台电脑为了同一个目标在一起工作。在web应用中,就是多个服务器提供一个站点的服务。
搭建php集群的第一步就是设置负载均衡。首先我们需要三台主机:
nginx负载:192.166.5.111php应用1:192.168.5.112php应用2:192.168.5.113
先前,在php应用所在的主机,我们需要安装nginx或者apache等这类web服务器,然后再在前面使用nginx作为负载。nginx 负载和php应用之间的通信是在应用层的,nginx 负载其实就相当于一个代理。但是,现在情况不同了。fastcgi技术的应用允许在php应用层可以不用再安装web服务器。现在php5.5版本已经将fpm作为内部模块支持了。在这种情况下,nginx 负载和php应用之间的通信是在传输层的,二者之间使用socket进行通信。当然了,这需要fpm服务的支持。
nginx设置 首先对nginx(192.168.5.111)进行设置,编辑nginx.conf配置文件
http{ …… upstream onmpw_phpapps{ server 192.168.18.88:9000; server 192.168.18.191:9000; } …… server{ listen 80; server_name load.onmpw.com ##这里是域名 root /www/onmpw …… location ~ \.php$ { root /www/onmpw ##这里是php应用所在目录 fastcgi_pass onmpw_phpapps; …… } }}
以上是对nginx进行的设置。其中只是包含了关键的部分,其余的和平常我们使用nginx+php作为web服务的时候进行的设置相同。
php所在主机设置 这里的设置就比较简单了。
首先编辑php-fpm.conf文件,修改监听的ip和端口,然后启动fpm服务
主机192.168.5.112
listen = 192.168.5.112:9000 //这里的端口可以自行设置。保存退出# /usr/local/php/sbin/php-fpm //开启服务
主机192.168.5.113
listen = 192.168.5.113:9000# /usr/local/php/sbin/php-fpm
到这里就对php的主机设置完成了。当然了,代码需要在两台主机上各上传一份儿。
好了,经过上面的设置,一个基本的php集群就已经搭建完成了。但是有一个问题,这种情况如果只是访问静态资源或者不进行交互的话是没有问题的。如果需要交互,那就涉及到一个session共享的问题。默认情况下php是将session存在本地磁盘上的。那这两台主机之间如何共享session呢,接下来我们就来解决这个问题。
php主机之间session共享 之前在网上看到过一种解决方式。由于php是将session存储在文件中,那我们可以在nginx负载主机上面搭建一个分布式文件系统(nfs),让两台php主机的session都存放在此文件系统中。以此来达到共享session的目的。
我个人比较倾向于将session存储到数据库中。因此这里我介绍的是将session存储到redis中。所以我们需要增加一台redis服务器
redis服务器:192.168.5.114
php默认情况下是不支持对redis的操作的。所以这里我们需要自己手动安装第三方的扩展,使其支持对redis的操作。关于如何使php支持redis,我们可以参考《php操作redis的两种方式》。
在这里我就认为我们的php已经支持redis了。接下来是将session存储到redis中,有两种方式:一种是直接修改php的配置文件php.ini;另一种是重写session机制。
修改php配置文件php.ini将session存储到redis中 使用vim打开php.ini,需要修改的有这两项:session.save_handler和session.save_path。
session.save_handler = redissession.save_path = “tcp://192.168.5.114:6379”//redis不需要密码验证session.save_path = “tcp://192.168.5.114:6379?auth=password”//redis 需要密码验证
修改完成,保存退出。然后重启php-fpm服务
# kill -int `cat /usr/local/php/var/run/php-fpm.pid`# /usr/local/php/sbin/php-fpm
两台php主机都做按照以上步骤操作。经过以上步骤,对于session的所有信息都保存到了redis中。从而实现了session的共享。
通过重写session机制将session存储到redis中 通常,在很多情况下我们是没有权限修改php.ini文件的。这时候我们可以通过重写session机制来修改session信息的存储。
对于重写session,php已经为我们提供了sessionhandlerinterface 接口。我们只要实现这个接口就可以了。关于如何重写session机制,大家可以参考 《php重写session机制》 这篇文章。并且我自己也重写了session的机制,该类的完整代码在github上,大家有兴趣的和可以 点此查看 。
总结 php集群的架构方式有很多种,但是其原理都大同小异。关键是找出最适合自己项目的最佳方案。例如:对于session存储方式的选择,你也可以选择使用memcache或者mysql数据库等。总之最适合自己的就是最优的。希望本文对大家有所帮助。
想阅读更多技术文章,请访问听云技术博客,访问听云官方网站感受更多应用性能优化魔力。