Nginx反向代理负载均衡的容器化部署
首先,在home
目录创建microservices
目录,开启第一篇章。
cd ~ && mkdir microservices && cd microservices
创建nginx
目录,在目录下分别创建三个节点目录:nginx01
、nginx02
、nginx03
,目的是使nginx01
作为反向代理服务器,将请求均衡转发到nginx02
、nginx03
。
mkdir -p ./nginx/nginx01 ./nginx/nginx02 ./nginx/nginx03
展示效果如下所示。
nginx
├── nginx01
└── nginx02
└── nginx03
将nginx镜像中的配置文件拷贝到各子目录中,以便做挂载,方法是创建一个临时容器,将配置文件拷贝至宿主机目录,再删除临时容器。
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目录如下所示。
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服务,配置文件分别映射到容器中的对应文件。
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
。
location / {
root /usr/share/nginx/html;
index index.html index.htm;
proxy_pass http://backend; #追加该行
}
配置完成后,执行以下命令将容器跑起来。
cd ~/microservices
docker-compose up
提示以下内容即成功。
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是将请求均衡转发到web02、web03的,这种方法叫轮询法,下篇文章介绍几种其他的负载算法。
Nginx反向代理负载均衡的容器化部署的更多相关文章
- Nginx 反向代理 负载均衡 虚拟主机配置
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- Nginx 反向代理 负载均衡 虚拟主机
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- 十.nginx反向代理负载均衡服务实践部署
期中集群架构-第十章-nginx反向代理负载均衡章节章节====================================================================== 0 ...
- 【转】Nginx 反向代理 负载均衡 虚拟主机配置
原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...
- Centos7.4 Nginx反向代理+负载均衡配置
Ningx是一款高性能的HTTP和反向代理服务器,配置起来也比较简单. 测试环境: 172.16.65.190 Nginx-反向代理 172.16.65.191 Ningx-Web 172.16.65 ...
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...
- 项目实战2.2—nginx 反向代理负载均衡、动静分离和缓存的实现
实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备注 nginx VIP:172.17.11.11 反向代理服务器 开启代理功能 设置监控,调度 rs01 RIP ...
- 项目实战2.1—nginx 反向代理负载均衡、动静分离和缓存的实现
总项目流程图,详见 http://www.cnblogs.com/along21/p/8000812.html 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 机器名称 IP配置 服务角色 备 ...
- 项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现
目录 实验一:实现反向代理负载均衡且动静分离 1.环境准备: 2.下载编译安装tengine 3.设置代理服务器的配置文件 4.启动tengine服务 5.开启后端的web服务 6.测试 实验二:ng ...
随机推荐
- Android菜鸟的成长笔记(23)——获取网络和SIM卡信息
TelephonyManager是一个管理手机通话状态.电话网络信息的服务类,该类提供了大量的getXxx()方法来获取电话网络的相关信息.这些信息包括设备编号.软件版本.网络运营商代号.网络运营商名 ...
- Java背景
Java语言是美国Sun公司(Stanford University Network),在1995年推出的高级编程语言 2009年Oracle甲骨文公司收购Sun公司
- 【16.67%】【codeforces 667C】Reberland Linguistics
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- Android Studio 报错Guest isn't online after 7 seconds 解决方案
最近使用真机模拟之后,再使用虚拟机就频繁出现这个问题; 解决步骤如下: 1.打开Android虚拟设备管理器, 2.查看Actoins栏下拉图标, 3.选择冷启动模式即可, 4.重启AVD正常;
- MyCat负载均衡 下篇
MyCat负载均衡 下篇 之前在 一步一步在Windows中使用MyCat负载均衡 上篇 中已经讲了如何配置出MyCat.下面讲其相关的使用. 五.配置MyCat-eye 对于MyCat监控官网还 ...
- 强烈推荐node包colors
库链接:colors 在你的 node.js 控制台中获取颜色
- CUDA页锁定内存(Pinned Memory)
对CUDA架构而言,主机端的内存被分为两种,一种是可分页内存(pageable memroy)和页锁定内存(page-lock或 pinned).可分页内存是由操作系统API malloc()在主机上 ...
- Netty:一种非易失堵塞client/server相框
Netty:一种非易失堵塞client/server相框 作者:chszs.转载需注明.博客主页:http://blog.csdn.net/chszs Netty是一个异步事件驱动的网络应用框架,为J ...
- VS编译环境中TBB配置和C++中lambda表达式
TBB(Thread Building Blocks),线程构建模块,是由Intel公司开发的并行编程开发工具,提供了对Windows,Linux和OSX平台的支持. TBB for Windows ...
- IT 达人
1. 手机与电脑多屏互动 [教程]华为多屏互动功能与PC win7的连接 要求手机和电脑必须在同一局域网内,且手机必须支持多屏互动功能. 操作步骤如下: PC 端: services.msc,启动下面 ...