Nginx实现基于业务类型的多集群调度,核心是通过upstream分组定义不同业务集群(如user_svc、order_svc、pay_svc),结合location路径匹配、map指令识别请求头或参数、if判断HTTP方法/内容类型,并配置健康检查与error_page降级机制,实现精准路由与容错。
在 Nginx 中实现基于业务类型的多集群调度,核心是把不同业务请求(如用户管理、订单处理、支付网关)精准路由到各自专属的后端集群,避免混用、干扰或单点过载。它不依赖外部服务发现,而是靠 Nginx 自身的 upstream 分组 + 请求特征识别 + 灵活匹配逻辑来完成。
这是最常用、最直观的方式。每个业务模块有明确路径前缀,Nginx 根据 location 规则直接绑定对应 upstream。
upstream user_svc { server 10.0.1.10:8080; server 10.0.1.11:8080; }upstream order_svc { server 10.0.2.20:9000; server 10.0.2.21:9000; }upstream pay_svc { server 10.0.3.30:7000; }
location /api/user/ { proxy_pass http://user_svc; }location /api/order/ { proxy_pass http://order_svc; }location /api/pay/ { proxy_pass http://pay_svc; }
当路径无法区分(比如都走 /api/v1/),可借助自定义 header(如 X-Biz-Type: finance)或 query 参数(如 ?biz=report)做动态路由。
map 指令将请求特征映射为 upstream 变量:map $http_x_biz_type $backend_cluster {<br> default user_svc;<br> "order" order_svc;<br> "pay" pay_svc;<br>}
location /api/ {<br> proxy_pass http://$backend_cluster;<br>}
某些业务对读写分离或媒体类型敏感,例如上传文件走专用集群,JSON API 和表单提交走不同后端。
$request_method 或 $content_type 判断:if ($request_method = POST) { set $backend upload_svc; }if ($content_type ~* "application/json") { set $backend api_svc; }
location /upload/ {<br> if ($request_method = POST) { proxy_pass http://upload_svc; break; }<br> proxy_pass http://default_svc;<br>}
业务集群不是静态列表,必须能自动规避故障节点,并在整组不可用时 fallback 到兜底服务(如只读缓存、降级页面或备用集群)。
upstream order_svc {<br> server 10.0.2.20:9000 max_fails=3 fail_timeout=30s;<br> server 10.0.2.21:9000 max_fails=3 fail_timeout=30s;<br> server 10.0.2.22:9000 backup;<br>}
location /api/order/ {<br> proxy_pass http://order_svc;<br> error_page 502 503 504 = @order_fallback;<br>}<br>location @order_fallback {<br> proxy_pass http://order_readonly_svc;<br>}