Nginx 做反向代理,一个服务优先被使用,当无法提供服务时才使用其他的备用服务

可以通过 Nginx 的 try_files 或 error_page 指令来实现请求的失败重试。你可以配置两个 HTTP 服务器,Nginx 会首先尝试访问服务器 A,如果无法访问,则代理到服务器 B。

以下是一个示例配置,演示如何实现这一逻辑:

nginx 复制代码
http {
    upstream server_a {
        server server_a_ip:port;  # A 服务器的 IP 和端口
    }

    upstream server_b {
        server server_b_ip:port;  # B 服务器的 IP 和端口
    }

    server {
        listen 80;
        server_name your_domain.com;  # 你的域名

        location / {
            # 尝试访问 A 服务器
            proxy_pass http://server_a;

            # 如果 A 服务器无法访问,则重试 B 服务器
            error_page 502 = @fallback;  # 502 Bad Gateway 错误表示 A 无法访问

            # 可以根据需要处理其他错误码
            error_page 504 = @fallback;  # 504 Gateway Timeout 错误也可以考虑重试
        }

        location @fallback {
            proxy_pass http://server_b;  # 代理到 B 服务器
        }
    }
}

配置说明:

  • upstream:定义了两个上游服务器,分别是 A 和 B。
  • location /:Nginx 会尝试先通过 proxy_pass 访问服务器 A。
  • error_page:当 A 返回 502 或 504 错误时,会重定向到 @fallback,即服务器 B。
  • location @fallback:在这里,Nginx 会代理请求到服务器 B。

注意事项:

确保 A 和 B 服务器的 IP 和端口正确配置。

这种方法使用了错误页面的重定向,当 A 返回可重试的错误时(如 502 或 504),Nginx 会尝试连接 B。

你可以根据需要自定义其他错误处理和重试逻辑。

通过这种配置,你可以在 A 服务器不可用时优雅地回退到 B 服务器。

相关推荐
潘晓可6 分钟前
Docker部署Bookstack
运维·docker·容器
Serverless社区8 分钟前
阿里云新发的AgentRun 有哪些“大招”,一文详解来了
运维·阿里云·云原生·serverless
倔强的石头10622 分钟前
Linux 进程深度解析(二):进程状态、fork 创建与特殊进程(僵尸 与 孤儿)
linux·运维·服务器
小李小李无与伦比35 分钟前
使用Simiki,部署.md文档
linux·运维·服务器
吃喝不愁霸王餐APP开发者1 小时前
霸王餐API网关层缓存:Nginx Proxy Cache与Cache-Control细节
nginx·spring·缓存
怀旧,1 小时前
【Linux系统编程】12. 基础IO(下)
linux·运维·服务器
网络小白不怕黑1 小时前
Docker Compose与私有仓库
运维·docker·容器
松涛和鸣1 小时前
29、Linux进程核心概念与编程实战:fork/getpid全解析
linux·运维·服务器·网络·数据结构·哈希算法
代码不行的搬运工2 小时前
显式拥塞通知(ECN)机制
运维·服务器·网络·算力网络
BJ_Bonree2 小时前
Bonree ONE 发布直通车| 如何利用核心链路,快速排查定位系统故障?
大数据·运维·人工智能