docker(二) - nginx负载均衡搞一搞

镜像下载

docker pull nginx

创建一个网络

docker network create network

这里最后面的'network'是我们自己给这个网络起得名字

目的是什么呢,我们自定义创建一个网络,是为了将一会创建的容器放到同一个网络环境中,他们之间才好通信。

默认的网络是桥接的方式,也就是容器通过宿主机可以访问外界网络。宿主机也可以访问到每个容器,但是容器之间是不能互相访问的。具体参见这里

启动三个nginx容器

lua 复制代码
docker run -d --network network --name nginx-1 -p 8080:80 nginx:latest
docker run -d --network network --name nginx-2 nginx:latest
docker run -d --network network --name nginx-3 nginx:latest

-p 将容器的指定端口映射到主机的指定端口,这里是将容器的80端口映射到主机的8080端口
--name 后面跟的 master 是自己设置的容器名
-d 指将在后台运行容器,并返回容器ID
--network 就是将这个容器加到network这个网络中

编辑nginx-1的配置文件

可以用装mysql那一期的方法,覆盖去改;也可以把宿主机的文件直接映射挂载过去;也可以直接进容器里编辑去改,这就直接编辑了。

bash 复制代码
docker exec -it nginx-1 bash

安装 vim 和 ping 命令

bash 复制代码
sed -i "s/deb.debian.org/mirrors.aliyun.com/g" /etc/apt/sources.list
apt update
apt install -y vim iputils-ping

装好之后可以直接ping一下,正常是可以ping通的

ping nginx-2
ping nginx-3
arduino 复制代码
vim /etc/nginx/conf.d/default.conf

在最上面加,这里的backend是起得名字,下面proxy_pass里需要一样

ini 复制代码
upstream backend { 
    server nginx-2; 
    server nginx-3; 
}

下面server中的location里面的配置进行修改保存

arduino 复制代码
location / {
    # root /usr/share/nginx/html;
    # index index.html index.htm;
    proxy_pass http://backend;
}

然后我们直接在容器里面来测试一下改的有没有问题

nginx -t

没问题之后咱们退出容器去重启这个容器,有问题咱们直接在容器里看日志解决就可以

docker restart nginx-1

测试一下

在nginx-1容器里curl 127.0.0.1是看不出来这个负载均衡到底配没配成功了,因此咱们改下nginx-2和nginx-3里面的html内容,就可以很直观的看到是哪台机器。

进入容器 nginx-2
bash 复制代码
docker exec -it nginx-2 bash
echo 'ngxin 2 号服务器'  >  /usr/share/nginx/html/index.html
进入容器 nginx-3
bash 复制代码
docker exec -it nginx-3 bash
echo 'ngxin 3 号服务器'  >  /usr/share/nginx/html/index.html
进入容器 nginx-1
curl 127.0.0.1

浏览器也可以直接看到

直接访问外网ip:8080 就可以啦

问题合集

  1. 启动之后发现忘记加到一个网络中了,除了删了重建还有啥方法
arduino 复制代码
docker network connect network nginx-1
  • 后面的network是我们上面自建的网络名
  • nginx-1 就是我们的容器

参考文章

相关推荐
AskHarries8 分钟前
Java字节码增强库ByteBuddy
java·后端
佳佳_22 分钟前
Spring Boot 应用启动时打印配置类信息
spring boot·后端
MonkeyKing_sunyuhua26 分钟前
ubuntu22.04 docker-compose安装postgresql数据库
数据库·docker·postgresql
追风林1 小时前
mac m1 docker本地部署canal 监听mysql的binglog日志
java·docker·mac
许野平2 小时前
Rust: 利用 chrono 库实现日期和字符串互相转换
开发语言·后端·rust·字符串·转换·日期·chrono
€☞扫地僧☜€2 小时前
docker 拉取MySQL8.0镜像以及安装
运维·数据库·docker·容器
茶馆大橘2 小时前
微服务系列六:分布式事务与seata
分布式·docker·微服务·nacos·seata·springcloud
全能全知者3 小时前
docker快速安装与配置mongoDB
mongodb·docker·容器
齐 飞3 小时前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
LunarCod4 小时前
WorkFlow源码剖析——Communicator之TCPServer(中)
后端·workflow·c/c++·网络框架·源码剖析·高性能高并发