Docker创建nginx+tomcat集群+redis版session共享

《Docker创建nginx+tomcat集群+redis版session共享》 单个docker集群

准备工作

  1. Docker环境,根据自己环境搭建

    《Docker创建nginx+tomcat集群+redis版session共享》 Windows环境下的Docker

  2. SpringBoot项目(加入spring-session-redis共享机制)下载地址

    《Docker创建nginx+tomcat集群+redis版session共享》 页面展示的信息

开始

  1. 首先把所需要的镜像拉去下来,拉alpine版,测试用没问题。

    • docker pull redis:alpine

    • docker pull nginx:alpine

    • docker pull tomcat:alpine

      《Docker创建nginx+tomcat集群+redis版session共享》 alpine小5倍

  2. 把redis启动起来,暴露6379端口,然后mvn构建项目。

    • docker run -d -p 6379:6379 redis redis-server --appendonly yes
    • 注:(这里springboot里yml文件redis地址配的是192.168.99.100,根据自己网络更改。
  3. 构建自己的tomcat镜像,并启动3个

    • 创建个目录,把打包好的hello.war放进来,并且vi Dockerfile
    FROM tomcat:alpine
    COPY hello.war /usr/local/tomcat/webapps
    
    • docker build -t tomcat:hello . 构建镜像

    • docker run -d tomcat:hello 启动3个tomcat,并记录ip地址

      《Docker创建nginx+tomcat集群+redis版session共享》 tomcat ip地址

    注:(tomcat容器重启后ip可能发生改变,可以直接开放端口
    docker run -d -p 8080:8080 tomcat:hello
    docker run -d -p 8081:8080 tomcat:hello
    docker run -d -p 8082:8080 tomcat:hello

  1. 启动Nginx,将本地的 nginx.conf 挂在到/etc/nginx/nginx.conf下
    $ docker run -d -p 80:80 -v /c/Users/Administrator/nginx/nginx/nginx.conf:/etc/nginx/nginx.conf nginx:alpine
    
  2. 修改nginx.conf配置,开启代理模式
    http{
    #省略其他配置
      upstream tomcats {
        #均衡策略
        #none 轮询(权重由weight决定)
        #ip_hash
        #fair
        #url_hash
        server 172.17.0.3:8080 ;
        server 172.17.0.4:8080 ;
        server 172.17.0.5:8080 ;
       }
     server {
        listen       80;
        server_name  localhost;
        #省略其他配置
        location / {
           root   /usr/share/nginx/html;
           index  index.html index.htm;
           proxy_pass http://tomcats;
           # 真实的客户端IP
           proxy_set_header   X-Real-IP        $remote_addr; 
        
        }
    }
    

    注:(指定端口的配置
    server 192.168.99.100:8080 ;
    server 192.168.99.100:8081 ;
    server 192.168.99.100:8082 ;

  3. 修改完保存退出,重启nginx容器 docker restart 1f
  • 多点几次,会发现只有项目id及项目ip发生改变,session不变。
  • 至此我们以实现单机创建nginx+tomcat负载均衡及session共享。

结束

本文参照极客学院nginx的视频,搭建的docker版,关于nginx,tomcat优化,有兴趣的可以去极客学院搜,讲的还不错。

    原文作者:Ocly
    原文地址: https://www.jianshu.com/p/c0901ff9b4ff
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞