web-dev-qa-db-ja.com

複数のフロントエンドまたはリスナーを使用せずにポートでルーティングするようにHAProxyを構成する方法

同じIP上の複数のポートで実行されるJabber接続用にHaproxy v1.5を構成しようとしています。構成をできるだけ単純にするために、単一のフロントエンドと1つ以上のバックエンドを使用したいと思います。送信元ポートをバックエンドに渡す方法、または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
4
Developr

単一のフロントエンドを使用し、バックエンドに多重化することは確かに可能です。バックエンドサーバーごとに1つのバックエンドセクションを追加する必要があります。

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

等.

11
Felix Frank