Day-08 基于 Docker安装 Nginx 镜像-负载均衡

1、反向代理后,自然而然就引出了负载均衡,下面简单实现负载均衡的效果;

2、实现该效果需要再添加一个 Nginx ,所以要增加一个文件夹。

bash 复制代码
/home
    |---mutou
           |----nginx
                  |----conf.d
                  |----html
                  |----conf.d2
                  |----html3

1.创建 html3 文件夹, 新建 index.html、index-test.html 文件

bash 复制代码
cd html3/
vi index.html
vi index-test.html

index.html、index-test.html 代码如下

html 复制代码
<html>
  <body>
    <h2>it is html3</h2>
  </body>
</html>

2. 修改 home/mutou/nginx/conf.d/default.conf 配置文件

bash 复制代码
vi defaul.conf

修改内容如下:

bash 复制代码
server {
    listen       80;
    server_name  localhost;
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
    location /demo {
       try_files $uri $uri/ /index-test.html;
    }
}

3. 重启 Docker 镜像

此时,查看所有运行中的docker容器

bash 复制代码
docker ps

然后重启该停止:

bash 复制代码
docker restart 容器id

4. 启动新容器, 挂载配置文件

ps: 端口为 8081 、 8080

bash 复制代码
docker run -d -p 8081:80 -v /home/mutou/nginx/conf.d:/etc/nginx/conf.d  -v /home/mutou/nginx/html3:/usr/share/nginx/html nginx
bash 复制代码
docker run -d -p 8080:80 -v /home/mutou/nginx/conf.d:/etc/nginx/conf.d  -v /home/mutou/nginx/html3:/usr/share/nginx/html nginx

5.配置负载均衡

1、访问ip/demo 时,平均分发到8080端口和8081端口上;

2、即it is html1it is html3间接出现;

配置负载均衡,那就是配置在第二次的nginx上,就是反向代理的nginx上,

我们去conf.d2文件夹下,修改default.conf文件,如下:

bash 复制代码
upstream group{
    server 58.87.88.124:8081;
    server 58.87.88.124:8080;
}
server {
    listen       80;
    server_name  localhost;
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
    location /demo {
        # 在该位置配置反向代理,将ip/demo1请求拦截,发送给8080端口,如果不是本机请使用公网ip
        proxy_pass  http://group;
    }
}

此时,查看所有运行中的docker容器:

bash 复制代码
docker ps

然后重启该容器:

bash 复制代码
docker restart 容器id

6. 查看效果

1、访问ip/demo,每次刷新页面;

2、页面都会在 html1 和 html3 中进行切换,此时负载均衡的效果就实现了。

7.配置负载均衡的权重

1、可以使用下面的配置修改两个端口的权重(即谁被访问的概率大);

ps: weight 越大权重越高 ;

bash 复制代码
upstream group1{
    server 你的刚才的ip地址:8080 weight=1;
    server 你的刚才的ip地址:8081 weight=10;
}

server {
    listen       80;
    server_name  localhost;
    location /demo1 {
        proxy_pass   http://group1/;
    }
}

ps: 修改配置文件, 保存退出, 然后重启该容器; 即可实现.

相关推荐
椎4952 小时前
苍穹外卖前端nginx错误之一解决
运维·前端·nginx
yannan201903132 小时前
Docker容器
运维·docker·容器
小宁爱Python3 小时前
Windows Docker Desktop占用C盘空间过大解决办法集合
运维·docker·容器
JAVA学习通3 小时前
发布自己的 jar 包到 Maven 中央仓库 ( mvnrepository.com )
人工智能·docker·自然语言处理·容器·rocketmq
木亦汐丫7 小时前
Docker 镜像版本Alpine、Slim、Bookworm、Bullseye、Stretch、Jessie
运维·docker·容器·debian·alpine·slim·bullseye
2301_787328498 小时前
25.负载均衡-Nginx、HAProxy、LVS 全解析
nginx·负载均衡·lvs
siriuuus8 小时前
Nginx 负载均衡调度算法
运维·nginx·负载均衡
中草药z9 小时前
【Docker】零基础上手:原理+Ubuntu/Windows GUI 安装 + 镜像源 / 目录优化
运维·ubuntu·docker·容器·gui·安装·cgroups
勇往直前plus9 小时前
如何利用docker部署springboot应用
spring boot·docker·容器
川石课堂软件测试11 小时前
全链路Controller压测负载均衡
android·运维·开发语言·python·mysql·adb·负载均衡