首先,在home
目录建立microservices
目录,开启第一篇章。php
cd ~ && mkdir microservices && cd microservices
复制代码
建立nginx
目录,在目录下分别建立三个节点目录:nginx01
、nginx02
、nginx03
,目的是使nginx01
做为反向代理服务器,将请求均衡转发到nginx02
、nginx03
。html
mkdir -p ./nginx/nginx01 ./nginx/nginx02 ./nginx/nginx03
复制代码
展现效果以下所示。nginx
nginx
├── nginx01
└── nginx02
└── nginx03
复制代码
将nginx镜像中的配置文件拷贝到各子目录中,以便作挂载,方法是建立一个临时容器,将配置文件拷贝至宿主机目录,再删除临时容器。git
docker run --name tmpnginx -d nginx:latest
docker cp tmpnginx:/etc/nginx/nginx.conf ~/microservices/nginx/nginx01
docker cp tmpnginx:/etc/nginx/nginx.conf ~/microservices/nginx/nginx02
docker cp tmpnginx:/etc/nginx/nginx.conf ~/microservices/nginx/nginx03
docker cp tmpnginx:/etc/nginx/conf.d ~/microservices/nginx/nginx01
docker cp tmpnginx:/etc/nginx/conf.d ~/microservices/nginx/nginx02
docker cp tmpnginx:/etc/nginx/conf.d ~/microservices/nginx/nginx03
docker rm -f tmpnginx
复制代码
此时nginx目录以下所示。github
nginx
├── nginx01
│ ├── conf.d
│ │ └── default.conf
│ └── nginx.conf
├── nginx02
│ ├── conf.d
│ │ └── default.conf
│ └── nginx.conf
└── nginx03
├── conf.d
│ └── default.conf
└── nginx.conf
复制代码
在根目录建立文件docker-compose.yml
,建立三个web服务,配置文件分别映射到容器中的对应文件。web
version: '3'
services:
web01: #服务名称
image: nginx:latest #镜像
container_name: web01 #容器名称
ports: #映射端口号,前者宿主机端口,后者容器端口
- 8080:80
volumes: #映射的目录或文件,前者宿主机目录,后者容器目录
- ./nginx/nginx01/nginx.conf:/etc/nginx/nginx.conf #配置文件
- ./nginx/nginx01/conf.d:/etc/nginx/conf.d #扩展配置目录
- ./nginx/html:/usr/share/nginx/html #html存放目录
web02:
image: nginx:latest
container_name: web02
volumes:
- ./nginx/nginx02/nginx.conf:/etc/nginx/nginx.conf
- ./nginx/nginx02/conf.d:/etc/nginx/conf.d
- ./nginx/html:/usr/share/nginx/html
web03:
image: nginx:latest
container_name: web03
volumes:
- ./nginx/nginx03/nginx.conf:/etc/nginx/nginx.conf
- ./nginx/nginx03/conf.d:/etc/nginx/conf.d
- ./nginx/html:/usr/share/nginx/html
复制代码
打开nginx/nginx01/conf.d/default.conf
,在文章顶部加入upstream
配置,web02与web03是docker-compose.yml
中定义的容器名称container_name
。算法
upstream backend {
server web02:80;
server web03:80;
}
复制代码
在location /
中加入proxy_pass
以便将请求转发给backend
。docker
location / {
root /usr/share/nginx/html;
index index.html index.htm;
proxy_pass http://backend; #追加该行
}
复制代码
配置完成后,执行如下命令将容器跑起来。浏览器
cd ~/microservices
docker-compose up
复制代码
提示如下内容即成功。bash
Recreating microservices_web01_1 ... done
Recreating microservices_web02_1 ... done
Recreating microservices_web03_1 ... done
Attaching to web02, web01, web03
复制代码
此时microservices
目录结构以下,nginx目录下多出了一个html
文件夹,能够在html
目录下建立一个index.html
,输入Hello world!
,从新跑一下。
microservices
├── docker-compose.yml
└── nginx
├── html
│ └── index.html
├── nginx01
│ ├── conf.d
│ │ └── default.conf
│ └── nginx.conf
├── nginx02
│ ├── conf.d
│ │ └── default.conf
│ └── nginx.conf
└── nginx03
├── conf.d
│ └── default.conf
└── nginx.conf
复制代码
如今作个测试,在浏览器中访问localhost:8080
,观察终端打印的日志。
web01 | 172.24.0.1 - - [26/Jun/2019:01:48:28 +0000] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36" "-"
web02 | 172.24.0.2 - - [26/Jun/2019:01:48:28 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36" "-"
复制代码
上述内容表示本次请求经过web01转发到了web02。
web01 | 172.24.0.1 - - [26/Jun/2019:04:42:36 +0000] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36" "-"
web03 | 172.24.0.2 - - [26/Jun/2019:04:42:36 +0000] "GET / HTTP/1.0" 304 0 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36" "-"
复制代码
再次刷新,能够看到请求经过web01转发到了web03,到目前为止,基本的负载均衡部署就已经完成了,上述的web01是将请求均衡转发到web0二、web03的,这种方法叫轮询法,下篇文章介绍几种其余的负载算法。
欢迎入伙Github开源书籍