【亲测有效】nginx负载均衡指定ip端口转发,做自动切换

nginx如何做到?监听两个目标公网ip,这两个目标ipA,ipB 是做了iptables的转发,按照端口转发的,例如我访问ipA的3333端口就转发某个squid代理x上,访问ipB的3333端口也转发到同一个squid代理x上。现在我访问nginx的3333端口,默认都走ipA转发,只有发现ipA不通或ipA转发不成功时ngnix自动切换到走ipB,我不用动任何代码。

可以通过配置 NGINX 的 stream 模块来实现。这个模块支持 TCP/UDP 的负载均衡与代理。你可以配置 NGINX 监听在一个端口,然后在检测到 IP A 不可达的情况下自动切换到 IP B。

下面是 NGINX 配置示例:

cpp 复制代码
stream {
    upstream squid_backend {
        server ipA:3333 max_fails=3 fail_timeout=30s;  # ipA的转发地址
        server ipB:3333 backup;                        # ipB的转发地址,作为备份
    }

    server {
        listen 3333;  # 监听的公网端口

        proxy_pass squid_backend;
        proxy_connect_timeout 1s;
        proxy_timeout 10s;
    }
}

配置说明:

  1. upstream块

    • ipA:3333:配置第一个目标 IP 和端口。
    • max_fails=3 fail_timeout=30s:在 30 秒内如果失败 3 次则标记该服务器为不可用。
    • ipB:3333 backup:配置第二个目标 IP 和端口,backup 表示只有在 ipA 不可用时才会使用 ipB
  2. server块

    • listen 3333:Nginx 监听的端口,这个端口将接收外部请求。
    • proxy_pass squid_backend:将请求转发到定义的 upstream 中的服务器。
    • proxy_connect_timeout 1s:设置连接超时时间为 1 秒。
    • proxy_timeout 10s:设置请求超时时间为 10 秒。

操作逻辑:

当用户访问 NGINX 的 3333 端口时,Nginx 会默认将请求转发到 ipA:3333。如果 ipA 无法连接或连续 3 次连接失败,那么 NGINX 会自动切换到 ipB:3333,不需要你修改任何代码。

请确保你已经编译 NGINX 时启用了 stream 模块,因为这个模块不是所有 NGINX 版本都默认启用的。

通过这种配置,可以达到你所需要的在 ipA 不可用时自动切换到 ipB 的效果。

相关推荐
梁正雄2 小时前
linux服务-Nginx+Tomcat+Redis之Session 共享
linux·nginx·tomcat
AI绘画小332 小时前
【网络安全】Wireshark 抓包过滤:源 / 目的 IP 过滤 + 命令大全
数据库·tcp/ip·测试工具·安全·web安全·wireshark
LaoZhangGong1232 小时前
TCP数据包格式分析
网络·网络协议·tcp/ip·以太网
老蒋新思维2 小时前
创客匠人 2025 高峰论谈(11.22-25):AI 智能体重构创始人 IP 打造与知识变现的管理逻辑
大数据·网络·人工智能·网络协议·tcp/ip·重构·知识付费
tang777896 小时前
如何保护网络隐私?从理解代理IP开始
网络·tcp/ip·php
dreamtm12311 小时前
通俗理解 TCP 拥塞控制:像 “快递员看路况调速”,避免网络 “堵车”
网络·tcp/ip·php
Cult Of11 小时前
TCP 与 UDP 的区别
网络协议·tcp/ip·udp
zhuyasen15 小时前
Go 实战:在 Gin 基础上上构建一个生产级的动态反向代理
nginx·go·gin
倦王15 小时前
Linux看ip,改用户名字加权限,在单独用户下设置miniconda
linux·服务器·tcp/ip
a123560mh17 小时前
国产信创操作系统银河麒麟常见软件适配(MongoDB、 Redis、Nginx、Tomcat)
linux·redis·nginx·mongodb·tomcat·kylin