HAProxy: 保存された状態を使用してバックエンド IP を復元できますか?

HAProxy: 保存された状態を使用してバックエンド IP を復元できますか?

私たちは、動的に割り当てられたバックエンド(統計ソケット経由で割り当てられたバックエンド IP とポート)を備えた Centos 7 で HAProxy 1.8.13 を使用しています。これは正常に動作します。

動的に割り当てられたものを再起動後も保持する方法が必要であり、「ファイルからサーバーの状態を読み込む" ディレクティブ。残念ながら、状態ファイルが構成された IP アドレスを復元しないというエラーが発生しています (または、これは設計上の問題でしょうか)。

テスト構成:

global
    log         127.0.0.1 local2
    chroot      /var/lib/haproxy
    pidfile     /var/run/haproxy.pid
    maxconn     4000
    user        haproxy
    group       haproxy
    daemon
    nbproc      2
    stats socket /run/haproxy/1.sock mode 0744 level admin process 1
    stats socket /run/haproxy/2.sock mode 0744 level admin process 2
    server-state-file /run/haproxy/server_state

defaults
    load-server-state-from-file global
    timeout server 10s
    timeout client 15s
    timeout queue 6s
    timeout connect 10s

frontend  main
    bind *:5000
    default_backend             app

backend app
    balance     roundrobin
    server  app1 127.0.0.1:5001 check
    server  app2 127.0.0.1:5002 check
    server  app3 127.0.0.1:5003 check
    server  app4 127.0.0.1:5004 check

スクリプトを使用して IP を設定し、次のように状態を保存します。

echo "show servers state" | socat /run/haproxy/1.sock - > /run/haproxy/server_state

たとえば、次のようになります。

1
# be_id be_name srv_id srv_name srv_addr srv_op_state srv_admin_state srv_uweight srv_iweight srv_time_since_last_change srv_check_status srv_check_result srv_check_health srv_check_state srv_agent_state bk_f_forced_id srv_f_forced_id srv_fqdn srv_port
7 app 1 app1 127.0.0.1 0 1 1 1 60 8 2 0 14 0 0 0 - 5001
7 app 2 app2 10.10.10.115 2 0 1 1 23 6 3 4 6 0 0 0 - 31501
7 app 3 app3 10.10.10.113 2 0 1 1 22 6 3 4 6 0 0 0 - 31375
7 app 4 app4 10.10.10.114 2 0 1 1 22 6 3 4 6 0 0 0 - 31400

haproxy が再起動すると、アップ/ダウン状態情報とポートが復元されますが、IP は 127.0.0.1 にリセットされます。

1
# be_id be_name srv_id srv_name srv_addr srv_op_state srv_admin_state srv_uweight srv_iweight srv_time_since_last_change srv_check_status srv_check_result srv_check_health srv_check_state srv_agent_state bk_f_forced_id srv_f_forced_id srv_fqdn srv_port
7 app 1 app1 127.0.0.1 0 1 1 1 7 8 2 0 14 0 0 0 - 5001
7 app 2 app2 127.0.0.1 0 0 1 1 2 8 2 0 6 0 0 0 - 31501
7 app 3 app3 127.0.0.1 0 0 1 1 2 8 2 0 6 0 0 0 - 31375
7 app 4 app4 127.0.0.1 0 0 1 1 1 8 2 0 6 0 0 0 - 31400

私たちは「初期化アドレス「ただし、これは DNS ベースのバックエンド アドレスにのみ影響します。何か間違ったことをしているのでしょうか? これは想定された動作ですか? それとも、何らかのバグでしょうか?

答え1

「127.0.0.1」を「localhost」に置き換えると動作することがわかりました。

HAProxy は、少なくともテストしたバージョン (1.8.7、1.8.13、1.9-dev) では、状態ファイル内のバックエンド IP を無視するようです。DNS 名がデフォルトで構成されているバックエンド サーバーは、適用された状態ファイルから IP を取得します。

私たちはコードを徹底的に調査し、HAProxy MLにパッチを当ててバグを発見しました。ここ

関連情報