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 就是我们的容器

参考文章

相关推荐
winks34 分钟前
Spring Task的使用
java·后端·spring
Null箘5 分钟前
从零创建一个 Django 项目
后端·python·django
秋意钟15 分钟前
Spring新版本
java·后端·spring
dessler23 分钟前
Docker-如何启动docker
运维·docker·云原生·容器·eureka
zhy2956323 分钟前
【DOCKER】基于DOCKER的服务之DUFS
运维·docker·容器·dufs
小蜗牛慢慢爬行35 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
与君共勉1213838 分钟前
Nginx 负载均衡的实现
运维·服务器·nginx·负载均衡
A小白59081 小时前
Docker部署实践:构建可扩展的AI图像/视频分析平台 (脱敏版)
后端
goTsHgo1 小时前
在 Spring Boot 的 MVC 框架中 路径匹配的实现 详解
spring boot·后端·mvc
waicsdn_haha1 小时前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk