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 服务器。

相关推荐
砖厂小工21 小时前
用 GLM + OpenClaw 打造你的 AI PR Review Agent — 让龙虾帮你审代码
android·github
程序员鱼皮1 天前
又一个新项目完结,我要出海了!
ai·github·开源项目
徐小夕1 天前
pxcharts-vue:一款专为 Vue3 打造的开源多维表格解决方案
前端·vue.js·github
Moment1 天前
想要长期陪伴你的助理?先从部署一个 OpenClaw 开始 😍😍😍
前端·后端·github
我叫黑大帅1 天前
前端如何利用 GitHub Actions 自动构建并发布到 GitHub Pages?
前端·面试·github
HelloGitHub1 天前
这个年轻的开源项目,想让每个人都能拥有自己的专业级 AI 智能体
开源·github·agent
刘发财1 天前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
sunny8652 天前
Claude Code 跨会话上下文恢复:从 8 次纠正到 0 次的工程实践
人工智能·开源·github
闲云一鹤2 天前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化