Nginx使用反向代理实现负载均衡过程解析
简介
基于docker容器以及docker-compose,所以需要自学docker在linux环境的基本使用
使用两个tomcat作为负载均衡的服务端
1.使用docker拉取tomcat和nginx镜像
2.使用docker-compose创建两个tomcat服务
新建tomcat目录,在该目录下创建docker-compose.yml文件,输入如下内容:
version: '3' services: tomcat1: image: tomcat container_name: tomcat1 ports: - 9090:8080 tomcat2: image: tomcat container_name: tomcat2 ports: - 9091:8080
在该docker-compose.yml同一目录下运行如下命令启动容器(-d 表示后台运行)
docker-compose up -d
成功后查看docker容器列表
命令
docker ps
结果示例有tomcat1和tomcat2两个容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 271dd3610d1d tomcat "catalina.sh run" 58 minutes ago Up 58 minutes 0.0.0.0:9091->8080/tcp tomcat2 fa19d20f0022 tomcat "catalina.sh run" 58 minutes ago Up 58 minutes 0.0.0.0:9090->8080/tcp tomcat1
以交互的方式进入容器,修改首页内容,以便区分两个tomcat(下面已tomcat为例)
命令
docker exec -it fa19d20f0022 bash
向首页追加内容
echo "9090" >> webapps/ROOT/index.jsp
3.创建nginx服务
新建nginx目录,在该目录下创建docker-compose.yml文件,输入如下内容:
version: '3.1' services: nginx: restart: always image: nginx container_name: nginx ports: - 81:80 volumes: - ./conf/nginx.conf:/etc/nginx/nginx.conf
由于docker-compose自动会将/conf/nginx.conf作为文件夹处理,所以需要在创建容器前,在nginx目录下,创建conf目录,在conf目录下,创建nginx.conf文件,并输入如下内容:
user nginx; worker_processes 1; events { worker_connections 1024; } http { upstream myapp1 { server [服务器ip]:9090 weight=10; server [服务器ip]:9091 weight=10; } server { listen 80; server_name [服务器ip]; location / { proxy_pass http://myapp1; } } }
在docker-compose.yml同一目录下运行
docker-compose up -d
4. 访问 [服务器ip]:81网址,多刷新几次,观察两个tomcat服务之间的切换
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支Fatmouse