蓝绿发布通过流量切换实现无感知部署,核心是路由控制、版本隔离与快速回滚;需双栈服务+七层网关(如Nginx),配置upstream指向蓝/绿环境,发布时验证→切流→观测,异常则秒级回滚,辅以自动化告警、Git化配置、Header标识、数据库向前兼容及静态资源哈希。
蓝绿发布在 Linux 环境下实现无感知部署,核心是通过流量切换而非停机更新,保障服务连续性。关键不在于“多一套环境”,而在于路由控制、版本隔离和快速回滚能力。
需提前部署两套独立的服务实例(蓝环境与绿环境),监听不同端口或 IP,但共用同一域名。推荐使用 Nginx 或 Traefik 作为七层网关,避免直接操作 DNS 或客户端负载均衡器——延迟高、不可控。
proxy_pass http://blue;
发布不是“启动新版本再关旧版”,而是“验证新版本 → 切流量 → 观察指标”,全程无需重启进程或中断连接。
/healthz)确认就绪nginx -s reload(毫秒级生效,已有连接不受影响)v1.1)、CPU/内存趋势一旦发现异常,回滚不是重跑部署脚本,而是秒级切回原 upstream,并保留绿环境待查。重点在于自动化验证和阈值告警。
deploy-rollback blue
真实生产中,蓝绿不只是“两套代码”,更是可观测性与协作流程的延伸。
X-Env: blue 和 X-Version: v1.0,便于排查问题时快速定位实例