nginx+docker+lamp+redis实现负载均衡和session共享
docker
docker是一种应用容器技术,其性能传统虚拟机是完全无法相比的,并且其沙箱技术能保证容器与物理机的隔离,实现安全可靠,在云计算时代,扮演者十分重要的角色。
安装docker
最新版的docker是按照年份和月份来确定的版本号,和以前的旧版不同,建议使用新版本。安装方法,网上很多。
apt-get install docker-ce
准备的镜像
- linode/lamp(主要是apache+php环境,数据库使用物理机)
- ubuntu(nginx)
- ubuntu(redis)
nginx
nginx是一个高性能的http服务器和反向代理服务器,它解决了c10k问题,
本文主要是利用其优秀的性能做后端集群服务器的反向代理服务器。
安装nginx
下载源码,官网下载
-
在ubuntu下编译安装,本文采用docker的Ubuntu镜像
具体安装方法本文不在赘述,网上教程很多。
-
安装后配置
安装后查看nginx的网络信息
ip : 172.17.0.2
nginx 端口 80
然后配置负载均衡后端服务器集群ip,本文假设只有两台服务器
ip : 172.17.0.3 和 172.17.0.4
lamp
lamp是linux下apache+php+mysql的运行环境,本文需要的只是apache和php运行环境,为了方便,直接从docker仓库pull下来linode/lamp进行测试,可以自己进行build一份lamp环境,如何使用docker来build自己网上搜索。
-
使用docker运行lamp镜像,并且将物理机代码映射到docker中的网站根目录下,保证所有后端服务器运行代码都是同一份。
docker run -it -v /home/codelover/docker/:/var/www/html/ linode/lamp
-
启动两个lamp,并且ip为上面nginx负载均衡配置的两个。
-
测试负载均衡
直接返回请求头消息,会发现请求是落在这两台服务器上,并且由于没有配置任何负载均衡模块,默认nginx使用论询机制。
redis
解决session共享问题
虽然现在负载均衡实现了,但是http服务器总是避免不了要记录用户登录状态的,传统的模式,一台服务器运行,直接记录在服务器上就可以,但是现在
,由于有了负载均衡,每次分发请求给服务器有可能不是同一台服务器,这就导致session不同步的问题,为了解决这个问题,nginx也有方案,ip_hash模块
,以及其他的第三方模块,如sticky。虽然可以解决这个问题,但是都把一个用户的请求发给了固定的一台服务器,服务器资源利用稍微还是有点不太让人满意。
因此,共享session就成了一个不错的解决方案。
其原理就是,把原保存在其中一台服务器上的session,共享到redis,让后端所有的服务器都能共享用户的登录状态,保证即使用户的请求被分到不同的后端服务器,
也能保证用户的状态能被服务器获取到。
具体实现,php可以配置php.ini
文件,或者利用php框架,比如yii就可以直接在框架中配置,具体我就不在赘述了。