Linux

如何在不使用多個前端或偵聽器的情況下將 HAProxy 配置為按埠路由

  • April 15, 2014

我正在嘗試為在同一 IP 上的多個埠上執行的 Jabber 連接配置 Haproxy v1.5。為了使配置盡可能簡單,我想使用一個前端和一個或多個後端。有沒有辦法讓我將源埠傳遞到後端或使用 ACL 根據埠路由到不同的後端?

frontend Jabber_IN
   bind 10.60.0.12:5222 name port5222
   bind 10.60.0.12:5223 name port5223
   bind 10.60.0.12:9090 name port9090
   bind 10.60.0.12:9091 name port9091
   bind 10.60.0.12:7070 name port7070
   bind 10.60.0.12:7443 name port7443
   bind 10.60.0.12:5229 name port5229 

   mode tcp
   option tcplog
   option tcpka

   timeout client 60m
   timeout server 60m
   timeout http-keep-alive 1m

   default_backend Jabber

backend Jabber
    tcp-check connect
    tcp-check send PING\r\n
    tcp-check expect string +PONG
   server Server1ZoneD 10.60.30.209:80  check
   server Server1ZoneE 10.60.47.4:80    check
   server Server2ZoneD 10.60.17.8:80    check
   server Server2ZoneE 10.60.45.219:80  check

使用單個前端並多路復用到後端確實是可能的。您將需要為每個後端伺服器添加一個後端部分,例如

backend JabberD1
   tcp-check connect
   tcp-check send PING\r\n
   tcp-check expect string +PONG
   server Server1ZoneD 10.60.30.209:80  check

backend JabberE1
   tcp-check connect
   tcp-check send PING\r\n
   tcp-check expect string +PONG
   server Server1ZoneE 10.60.47.4:80    check

等等

在您的前端,像這樣拆分流量

   acl d1 dst_port 5222
   use_backend JabberD1 if d1

等等

引用自:https://serverfault.com/questions/577103