[Nginx]反向代理和负载均衡

目录

反向代理

反向代理的配置

负载均衡

负载均衡的配置

负载均衡的策略

总结

反向代理

访问某个网站时,前端接口和后端接口不是一样

这是Nginx反向代理的功能,将前端发送的动态请求发送到后端服务器,后端服务器处理完请求,将响应返回给反向代理,反向代理再将响应返回给客户端。​​客户端并不知道请求具体是由哪个后端服务器处理的,以为就是反向代理在处理请求。​

这样做最主要的好处有三个:

  1. 隐藏后端服务器:​ 保护真正的应用服务器免受直接的外部攻击。
  2. 负载均衡:​ 作为负载均衡器的基础。
  3. 提高访问速度

反向代理的配置

在nginx.conf文件中配置

复制代码
server {
    listen 80; # 监听端口 80 (HTTP)
    server_name example.com; # 负责响应对 example.com 的请求

    location / {
        # 将匹配 / 路径的所有请求转发给后端服务器组 `backend_servers`
        proxy_pass http://backend_servers; 
    }
}

# 定义后端服务器集群
upstream backend_servers {
    server 服务器1地址:端口; # 后端应用服务器1地址和端口
    server 服务器2地址:端口; # 后端应用服务器2地址和端口
}

负载均衡

  • 是什么:​​Nginx 反向代理功能的一个扩展和核心应用场景。指 Nginx 将接收到的客户端请求,按照某种预定义的策略,分发到多个后端服务器上进行处理的过程。
  • ​目的:​ ​分摊负载、提高并发处理能力、提升系统整体性能和可用性。​ 当一台后端服务器故障时,Nginx可以将请求转发给其他健康的服务器。

负载均衡的配置

其实跟反向代理基本一样

复制代码
upstream backend_pool { # 定义一个后端服务器池,名为 backend_pool
    # 定义服务器,地址:端口(可选权重和其他参数)
    server backend1.example.com weight=3;  # 权重为 3
    server backend2.example.com:8080;       # 权重默认为 1
    server 192.168.100.103 backup;         # 备份服务器,当主服务器宕机后才启用
    # 可以配置其他负载均衡算法和参数
    # least_conn; # 如果指定为最少连接算法
}

server {
    listen 80;
    server_name myapp.com;

    location / {
        proxy_pass http://backend_pool; # 将请求代理转发到上面定义的 backend_pool 池
        # ... 其他反向代理相关配置(如proxy_set_header)...
    }
}

负载均衡的策略

  • 轮询:​ 默认策略。依次将新请求分发到池中的每个后端服务器。配合 weight 参数可以实现​加权轮询​ (权重高的服务器承担更多请求)。
    • 示例: server backend1 weight=5; server backend2; (backend1 处理大约 5/6 的请求,backend2 处理 1/6)。
  • ​最少连接:​ 将请求发送到当前​活动连接数最少​ 的后端服务器。需要配置 least_conn;
    • 场景: 当后端服务器处理请求能力差异较大或请求耗时长短不一时更公平。
  • ​IP 哈希:​ 根据客户端 IP 地址计算哈希值,将同一客户端的请求​固定​ 转发给某个后端服务器(除非该服务器不可用)。需要配置 ip_hash;
    • 场景: 需要维护用户会话状态(Session)的应用,避免了 Session 同步的复杂性。但其固定分配特性可能不够均衡。
  • ​URL 哈希:​ 根据请求的 URL 计算哈希值进行分配。使用第三方模块(如 ngx_http_upstream_hash_module)或商业版支持。

总结

Nginx 反向代理​ ​是让 Nginx 作为一个中介,代表后端服务器接收并处理客户端请求。核心配置在 proxy_pass

​Nginx 负载均衡​ ​是反向代理的自然延伸和应用,当反向代理目标指向一组服务器(upstream)时,Nginx 负责按照特定策略将新请求分配给组内不同的服务器,以达到提高性能和高可用的目的。

相关推荐
大柏怎么被偷了1 小时前
【Linux】进程等待
linux·运维·服务器
云和数据.ChenGuang2 小时前
运维面试题之oracle和mysql单表最大容量
运维·mysql·oracle
酷柚易汛智推官2 小时前
Fastlane赋能移动研发:从全流程自动化到工程效能升级
运维·自动化·酷柚易汛
落798.2 小时前
Genlogin × Bright Data,一键解锁自动化采集的高成功率方案
运维·自动化·数据采集·亮数据
羑悻的小杀马特2 小时前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
L***86533 小时前
Failed to restart nginx.service Unit nginx.service not found
运维·nginx
十六年开源服务商4 小时前
WordPress运维服务怎样提供客户服务支持
运维
chxii4 小时前
PHP 配置全解析:Apache vs Nginx 的线程安全差异与 Windows 实战指南
运维·php
想唱rap5 小时前
C++ map和set
linux·运维·服务器·开发语言·c++·算法
fruge5 小时前
前端文档自动化:用 VitePress 搭建团队技术文档(含自动部署)
运维·前端·自动化