Nginx实现反向代理负载均衡实验

实验环境:

VM REdhat虚拟机(192.168.87.5)一台、VM Redhat虚拟机(192.168.87.3)一台、阿里云服务器(47.93.79.92)一台

**实验要求:**通过windows浏览器访问192.168.87.5(虚拟机配置nginx)时,能够访问到192.168.87.3:80虚拟机的web服务和47.93.79.92:80(云服务器)的web服务。

一、首先确保虚拟机nginx服务开启,查看默认index.html文件是否存在

bash 复制代码
cd /usr/share/nginx/html/

二、修改虚拟机的Nginx配置文件

bash 复制代码
vim /etc/nginx/nginx.conf

修改配置文件以下几处:

其中upstream 用来配置反向代理的后端服务器,实验中有两个;

weight代表权重,可以自由更改;

max_fails=2表示最多失败两次;

fail_timeout=30s表示失败超时时间30s;

server_name 设置为你要匹配的服务器域名或者ip,当客户端发送请求时,Nginx 将会根据 server_name 来选择合适的 server 块进行处理。你可以设置多个域名,使用空格分隔开;

proxy_pass 用于配置反向代理。它用于将客户端的请求转发(代理)到指定的后端服务器,它将所有的请求代理到名为backend的upstream定义的一组后端服务器。

bash 复制代码
    upstream backend{
             server 192.168.87.3:80 weight=200 max_fails=2 fail_timeout=30s;
             server 47.93.79.92:80 weight=100 max_fails=2 fail_timeout=30s;
                }

    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  192.168.87.5;
        root         /usr/share/nginx/html/;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
            proxy_pass http://backend;
        }

        error_page 404 /404.html;
            location = /40x.html {
            }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
}

保存并退出

三、我们尝试在windows上进行访问http://192.168.87.5

访问到的是云服务器的web服务

更改权重,重启nginx服务,再次刷新页面(或清除缓存刷新)

访问到的是Redhat虚拟机的web服务

至此,配置nginx实现反向代理、负载均衡实验结束

如果我们需要配置轮询方式的负载均衡,只需要更改nginx.conf的如下配置:

bash 复制代码
    upstream backend{
        server 47.93.79.92:80;
        server 192.168.87.3:80;
          }

页面表现就是每刷新一次,就会跳转到另一台后端。

注意:如果你的电脑资源不够,可以用两台虚拟机或者一台虚拟机和一台云服务器访问,如果你要在两台虚拟机之间实现,请确保开启负载均衡的虚拟机的web服务端口不是80,或者更改你的listen端口,否则会形成回路,导致无论如何也访问不了开启负载均衡的那台虚拟机的web。

相关推荐
NineData1 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
梦想很大很大21 小时前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
Sinclair1 天前
内网服务器离线安装 Nginx+PHP+MySQL 的方法
运维
叶落阁主1 天前
Tailscale 完全指南:从入门到私有 DERP 部署
运维·安全·远程工作
十二7401 天前
前端缓存踩坑实录:从版本号管理到自动化构建
前端·javascript·nginx
可观测性用观测云2 天前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes
甲鱼9292 天前
MySQL 实战手记:日志管理与主从复制搭建全指南
运维
闲云一鹤4 天前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
碳基沙盒4 天前
OpenClaw 多 Agent 配置实战指南
运维
蝎子莱莱爱打怪7 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes