
私たちは、動的に割り当てられたバックエンド(統計ソケット経由で割り当てられたバックエンド 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にパッチを当ててバグを発見しました。ここ。