nginx+docker+lamp+redis实现负载均衡和session共享

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

  1. 下载源码,官网下载

  2. 在ubuntu下编译安装,本文采用docker的Ubuntu镜像

    具体安装方法本文不在赘述,网上教程很多。

  3. 安装后配置

    安装后查看nginx的网络信息

    nginx_net

    ip : 172.17.0.2

    nginx 端口 80

    然后配置负载均衡后端服务器集群ip,本文假设只有两台服务器

    nginx_config

    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自己网上搜索。

  1. 使用docker运行lamp镜像,并且将物理机代码映射到docker中的网站根目录下,保证所有后端服务器运行代码都是同一份。

    docker run -it -v /home/codelover/docker/:/var/www/html/ linode/lamp

  2. 启动两个lamp,并且ip为上面nginx负载均衡配置的两个。


    apache
  1. 测试负载均衡

    server1

    server2
直接返回请求头消息,会发现请求是落在这两台服务器上,并且由于没有配置任何负载均衡模块,默认nginx使用论询机制。

redis解决session共享问题

虽然现在负载均衡实现了,但是http服务器总是避免不了要记录用户登录状态的,传统的模式,一台服务器运行,直接记录在服务器上就可以,但是现在
,由于有了负载均衡,每次分发请求给服务器有可能不是同一台服务器,这就导致session不同步的问题,为了解决这个问题,nginx也有方案,ip_hash模块
,以及其他的第三方模块,如sticky。虽然可以解决这个问题,但是都把一个用户的请求发给了固定的一台服务器,服务器资源利用稍微还是有点不太让人满意。

因此,共享session就成了一个不错的解决方案。

其原理就是,把原保存在其中一台服务器上的session,共享到redis,让后端所有的服务器都能共享用户的登录状态,保证即使用户的请求被分到不同的后端服务器,
也能保证用户的状态能被服务器获取到。

具体实现,php可以配置php.ini文件,或者利用php框架,比如yii就可以直接在框架中配置,具体我就不在赘述了。

你可能感兴趣的:(nginx+docker+lamp+redis实现负载均衡和session共享)