Skip to content

Commit

Permalink
fix: support PROXY for TCP health checks
Browse files Browse the repository at this point in the history
  • Loading branch information
maxmoehl committed Jan 9, 2025
1 parent 214f27a commit bf84139
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 1 deletion.
12 changes: 12 additions & 0 deletions jobs/haproxy/templates/haproxy.config.erb
Original file line number Diff line number Diff line change
Expand Up @@ -1040,8 +1040,20 @@ listen health_check_http_tcp-<%= tcp_proxy["name"] %>
bind :<%= tcp_proxy["health_check_http"] %>
mode http
monitor-uri /health
<%- if p("ha_proxy.accept_proxy") && !p("ha_proxy.disable_health_check_proxy") -%>
tcp-request connection expect-proxy layer4 unless LOCALHOST
<%- end -%>
acl tcp-<%= tcp_proxy["name"] %>-routers_down nbsrv(tcp-<%= tcp_proxy["name"] %>) eq 0
monitor fail if tcp-<%= tcp_proxy["name"] %>-routers_down

<%- if p("ha_proxy.expect_proxy_cidrs", []).size > 0 -%>
listen health_check_http_tcp-<%= tcp_proxy["name"] %>_proxy_protocol
bind :<%= tcp_proxy["health_check_http"] + 1 %> accept-proxy
mode http
monitor-uri /health
acl tcp-<%= tcp_proxy["name"] %>-routers_down nbsrv(tcp-<%= tcp_proxy["name"] %>) eq 0
monitor fail if tcp-<%= tcp_proxy["name"] %>-routers_down
<%- end -%>
<%- end -%>
<% end -%>

Expand Down
7 changes: 6 additions & 1 deletion spec/haproxy/templates/haproxy_config/frontend_tcp_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,8 @@
'name' => 'redis',
'port' => 6379,
'backend_servers' => ['10.0.0.1', '10.0.0.2'],
'ssl' => true
'ssl' => true,
'health_check_http' => 9095
}, {
'name' => 'mysql',
'port' => 3306,
Expand Down Expand Up @@ -135,6 +136,10 @@
expect(frontend_tcp_mysql).to include('bind :3306')
expect(frontend_tcp_mysql).to include('tcp-request connection expect-proxy layer4 if { src -f /var/vcap/jobs/haproxy/config/expect_proxy_cidrs.txt }')
end

it 'adds a _proxy_protocol health check' do
expect(haproxy_conf['listen health_check_http_tcp-redis_proxy_protocol']).to include('bind :9096 accept-proxy')
end
end
end

Expand Down
1 change: 1 addition & 0 deletions spec/spec_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ def ttar_entry(ttar, path)
# }
def parse_haproxy_config(config) # rubocop:disable Metrics/AbcSize
# remove comments and empty lines
# puts config
config = config.split("\n").reject { |l| l.empty? || l =~ /^\s*#.*$/ }.join("\n")

# split into top-level groups
Expand Down

0 comments on commit bf84139

Please sign in to comment.