加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 如何配置HAProxy以按端口路由而不使用多个前端或侦听器

发布时间:2020-12-14 02:52:33 所属栏目:Linux 来源:网络整理
导读:我正在尝试为同一IP上的多个端口上运行的Jabber连接配置Haproxy v1.5.为了使配置尽可能简单,我想使用单个前端和一个或多个后端.有没有办法让我将源端口传递给后端或使用ACL根据端口路由到不同的后端? frontend Jabber_IN bind 10.60.0.12:5222 name port522
我正在尝试为同一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 PINGrn
     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 PINGrn
    tcp-check expect string +PONG
    server Server1ZoneD 10.60.30.209:80  check

backend JabberE1
    tcp-check connect
    tcp-check send PINGrn
    tcp-check expect string +PONG
    server Server1ZoneE 10.60.47.4:80    check

等等

在您的前端,像这样拆分流量

acl d1 dst_port 5222
    use_backend JabberD1 if d1

等等

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读