www.icesr.com
IT运维工程师的摇篮

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

单个docker集群

准备工作

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

  2. SpringBoot项目(加入spring-session-redis共享机制)下载地址
    页面展示的信息

开始

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

    • docker pull redis:alpine
    • docker pull nginx:alpine
    • docker pull tomcat:alpine

      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

      <code><span class="hljs-keyword">FROM</span> tomcat:alpine
      <span class="hljs-keyword">COPY</span> hello.war /usr/local/tomcat/webapps</code>
    • docker build -t tomcat:hello . 构建镜像

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

      tomcat ip地址

  4. 启动Nginx,将本地的 nginx.conf 挂在到/etc/nginx/nginx.conf下

    <code>$ docker run <span class="hljs-attribute">-d</span> <span class="hljs-attribute">-p</span> <span class="hljs-number">80</span>:<span class="hljs-number">80</span> <span class="hljs-attribute">-v</span> /c/Users/Administrator/nginx/nginx/nginx<span class="hljs-built_in">.</span>conf:/etc/nginx/nginx<span class="hljs-built_in">.</span>conf nginx:alpine</code>
  5. 修改nginx.conf配置,开启代理模式

    <code>http{
    
    <span class="hljs-preprocessor">#省略其他配置</span>
    
      upstream tomcats {
        <span class="hljs-preprocessor">#均衡策略</span>
        <span class="hljs-preprocessor">#none 轮询(权重由weight决定)</span>
        <span class="hljs-preprocessor">#ip_hash</span>
        <span class="hljs-preprocessor">#fair</span>
        <span class="hljs-preprocessor">#url_hash</span>
        <span class="hljs-keyword">server</span> <span class="hljs-number">172.17</span><span class="hljs-number">.0</span><span class="hljs-number">.3</span>:<span class="hljs-number">8080</span> ;
        <span class="hljs-keyword">server</span> <span class="hljs-number">172.17</span><span class="hljs-number">.0</span><span class="hljs-number">.4</span>:<span class="hljs-number">8080</span> ;
        <span class="hljs-keyword">server</span> <span class="hljs-number">172.17</span><span class="hljs-number">.0</span><span class="hljs-number">.5</span>:<span class="hljs-number">8080</span> ;
       }
     s erver {
        listen       <span class="hljs-number">80</span>;
        server_name  localhost;
        <span class="hljs-preprocessor">#省略其他配置</span>
        location / {
           root   /usr/share/nginx/html;
           <span class="hljs-keyword">index</span>  <span class="hljs-keyword">index</span>.html <span class="hljs-keyword">index</span>.htm;
           proxy_pass http:<span class="hljs-comment">//tomcats;</span>
           <span class="hljs-preprocessor"># 真实的客户端IP</span>
           proxy_set_header   X-Real-IP        $remote_addr; 
    
        }
    }</code>
  6. 修改完保存退出,重启nginx容器 docker restart 1f

    • 浏览器访问 http://192.168.99.100/hello/

    • 多点几次,会发现只有项目id及项目ip发生改变,session不变。
    • 至此我们以实现单机创建nginx+tomcat负载均衡及session共享。

结束

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

未经允许不得转载:冰点网络 » Docker创建nginx+tomcat集群+redis版session共享

分享到:更多 ()

评论 抢沙发

评论前必须登录!