准备工作
-
Docker环境,根据自己环境搭建
-
SpringBoot项目(加入spring-session-redis共享机制)下载地址
开始
-
首先把所需要的镜像拉去下来,拉alpine版,测试用没问题。
docker pull redis:alpine
docker pull nginx:alpine
-
docker pull tomcat:alpine
-
把redis启动起来,暴露6379端口,然后mvn构建项目。
docker run -d -p 6379:6379 redis redis-server --appendonly yes
- 注:(这里springboot里yml文件redis地址配的是192.168.99.100,根据自己网络更改。
-
构建自己的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地址
注:(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
- 创建个目录,把打包好的hello.war放进来,并且
- 启动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
- 修改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 ;
- 修改完保存退出,重启nginx容器
docker restart 1f
- 多点几次,会发现只有项目id及项目ip发生改变,session不变。
- 至此我们以实现单机创建nginx+tomcat负载均衡及session共享。
结束
本文参照极客学院nginx的视频,搭建的docker版,关于nginx,tomcat优化,有兴趣的可以去极客学院搜,讲的还不错。