一个使用 Nginx 进行反向代理和负载均衡的示例配置

假设你有两个后端服务器(backend1 和 backend2),并且你希望 Nginx 将请求分发到这两个服务器上。

1、安装 Nginx

首先,确保你已经安装了 Nginx。如果没有安装,可以使用以下命令进行安装(以 CentOS 为例):

复制代码
sudo yum install epel-release
sudo yum install nginx

2、配置 Nginx

编辑 Nginx 的配置文件,通常位于 /etc/nginx/nginx.conf 或 /etc/nginx/conf.d/ 目录下。你可以创建一个新的配置文件,例如 proxy.conf。

复制代码
sudo vim /etc/nginx/conf.d/proxy.conf

3、示例配置

以下是一个完整的 Nginx 配置示例,展示了如何设置反向代理和负载均衡:

复制代码
# 定义上游服务器组
upstream backend {
    server backend1.example.com:80;
    server backend2.example.com:80;
    # 可以添加更多的服务器
    # server backend3.example.com:80;
}

# 配置 HTTP 服务器
server {
    listen 80;
    server_name example.com;

    # 访问日志
    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    # 反向代理配置
    location / {
        proxy_pass http://backend;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }

    # 可以根据需要添加其他 location 块
    # location /api/ {
    #     proxy_pass http://backend;
    #     proxy_set_header Host $host;
    #     proxy_set_header X-Real-IP $remote_addr;
    #     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    #     proxy_set_header X-Forwarded-Proto $scheme;
    # }
}

4、 解释配置

  • upstream backend: 定义了一个名为 backend 的服务器组,包含两个后端服务器 backend1.example.combackend2.example.com
  • server: 配置了一个 HTTP 服务器,监听 80 端口,并处理 example.com 的请求。
  • location /: 将所有请求反向代理到 backend 服务器组,并设置了一些常用的请求头。

5、测试配置

在保存配置文件后,测试 Nginx 配置是否正确:

复制代码
sudo nginx -t

6、重新加载 Nginx

如果配置文件没有问题,重新加载 Nginx 以应用新的配置:

复制代码
sudo systemctl reload nginx

7、 验证

打开浏览器,访问 http://example.com,你应该会看到请求被分发到 backend1 和 backend2 服务器上。你可以通过查看后端服务器的日志来确认请求是否被正确分发。

8、负载均衡算法

Nginx 支持多种负载均衡算法,包括轮询(默认)、IP 哈希、最少连接等。以下是一些示例:

9、 健康检查

Nginx 本身不支持内置的健康检查,但可以通过第三方模块(如 nginx_upstream_check_module)来实现。以下是一个简单的示例:

  • 安装 nginx_upstream_check_module

    下载并编译 Nginx 及模块

    wget http://nginx.org/download/nginx-1.21.3.tar.gz
    tar -zxvf nginx-1.21.3.tar.gz
    git clone https://github.com/yaoweibin/nginx_upstream_check_module.git

    cd nginx-1.21.3
    ./configure --add-module=../nginx_upstream_check_module
    make
    sudo make install

  • 配置健康检查

    upstream backend {
    server backend1.example.com:80;
    server backend2.example.com:80;
    check interval=3000 rise=2 fall=5 timeout=1000 type=http;
    check_http_send "HEAD /healthcheck HTTP/1.0\r\n\r\n";
    check_http_expect_alive http_2xx http_3xx;
    }

    server {
    listen 80;
    server_name example.com;

    复制代码
      location /status {
          check_status;
          access_log off;
          allow 127.0.0.1;
          deny all;
      }
    
      location / {
          proxy_pass http://backend;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_set_header X-Forwarded-Proto $scheme;
      }

    }

通过以上步骤,你可以配置一个基本的 Nginx 反向代理和负载均衡。

相关推荐
GodGump2 小时前
dbgpt7.0 docker部署
运维·docker·容器
Wnq100726 小时前
智能巡检机器人在化工企业的应用研究
运维·计算机视觉·机器人·智能硬件·deepseek
tf的测试笔记9 小时前
测试团队UI自动化实施方案
运维·自动化
TDD_06289 小时前
【运维】Centos硬盘满导致开机时处于加载状态无法开机解决办法
linux·运维·经验分享·centos
头孢头孢9 小时前
k8s常用总结
运维·后端·k8s
遇码9 小时前
单机快速部署开源、免费的分布式任务调度系统——DolphinScheduler
大数据·运维·分布式·开源·定时任务·dolphin·scheduler
爱编程的王小美10 小时前
Docker基础详解
运维·docker·容器
学习至死qaq10 小时前
windows字体在linux访问异常
linux·运维·服务器
IEVEl10 小时前
Centos7 安装 TDengine
运维·centos·时序数据库·tdengine
在野靡生.11 小时前
Ansible(4)—— Playbook
linux·运维·ansible