[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 负责按照特定策略将新请求分配给组内不同的服务器,以达到提高性能和高可用的目的。

相关推荐
小天源7 小时前
Cacti在Debian/Ubuntu中安装及其使用
运维·ubuntu·debian·cacti
Trouvaille ~7 小时前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
芷栀夏7 小时前
深度解析 CANN 异构计算架构:基于 ACL API 的算子调用实战
运维·人工智能·开源·cann
全栈工程师修炼指南8 小时前
Nginx | stream 四层反向代理:SSL、PREREAD 阶段模块指令浅析与实践
运维·网络·网络协议·nginx·ssl
威迪斯特9 小时前
CentOS图形化操作界面:理论解析与实践指南
linux·运维·centos·组件·图形化·桌面·xserver
一方热衷.9 小时前
在线安装对应版本NVIDIA驱动
linux·运维·服务器
独自归家的兔9 小时前
ubuntu系统安装dbswitch教程 - 备份本地数据到远程服务器
linux·运维·ubuntu
ONE_SIX_MIX9 小时前
ubuntu 24.04 用rdp连接,桌面黑屏问题,解决
linux·运维·ubuntu
龙飞059 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
春日见9 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器