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: 修改配置文件, 保存退出, 然后重启该容器; 即可实现.

相关推荐
喜欢你,还有大家22 分钟前
Docker-仓库-镜像制作
运维·docker·容器
武子康3 小时前
Java-166 Neo4j 安装与最小闭环 | 10 分钟跑通 + 远程访问 Docker neo4j.conf
java·数据库·sql·docker·系统架构·nosql·neo4j
toooooop83 小时前
Nginx 反向代理 HTTPS CDN 配置检查清单(避坑版)
运维·nginx·https·cdn
群联云防护小杜3 小时前
国产化环境下 Web 应用如何满足等保 2.0?从 Nginx 配置到 AI 防护实战
运维·前端·nginx
计算机小手6 小时前
使用 llama.cpp 在本地高效运行大语言模型,支持 Docker 一键启动,兼容CPU与GPU
人工智能·经验分享·docker·语言模型·开源软件
尽兴-6 小时前
[特殊字符] 微前端部署实战:Nginx 配置 HTTPS 与 CORS 跨域解决方案(示例版)
前端·nginx·https·跨域·cors·chrom
岚天start7 小时前
KubeSphere在线安装单节点K8S集群
docker·容器·kubernetes·k8s·kubesphere·kubekey
栗子~~7 小时前
shell-基于k8s/docker管理容器、监控模型训练所消耗的最大CPU与最大内存脚本
docker·容器·kubernetes
半梦半醒*7 小时前
k8s——pod详解2
linux·运维·docker·容器·kubernetes·负载均衡
AAA小肥杨7 小时前
K8s从Docker到Containerd的迁移全流程实践
docker·容器·kubernetes