cd352c0dbe
After giving it some thought, it could pretty well happen that other protocols benefit from the sticky algorithm that some used to emulate using a "stick-on int(0)" or things like this previously. So better rename it to "sticky" right now instead of having to keep that "log-" prefix forever. It's still limited to logs, of course, only the algo is renamed in the config.
186 lines
4.3 KiB
Plaintext
186 lines
4.3 KiB
Plaintext
varnishtest "Test the log backend target"
|
|
feature cmd "$HAPROXY_PROGRAM -cc 'version_atleast(2.9-dev0)'"
|
|
feature ignore_unknown_macro
|
|
|
|
server s1 {
|
|
rxreq
|
|
txresp
|
|
} -repeat 500 -start
|
|
|
|
syslog Slg1 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /0 HTTP/1.1\""
|
|
} -repeat 100 -start
|
|
|
|
syslog Slg2 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /1 HTTP/1.1\""
|
|
} -repeat 100 -start
|
|
|
|
syslog Slg21 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /srv1 HTTP/1.1\""
|
|
} -repeat 1 -start
|
|
|
|
syslog Slg22 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /srv2 HTTP/1.1\""
|
|
} -repeat 1 -start
|
|
|
|
syslog Slg23 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /srv3 HTTP/1.1\""
|
|
} -repeat 2 -start
|
|
|
|
syslog Slg24 -level info {
|
|
recv
|
|
expect ~ "[^:\\[ ]\\[${h1_pid}\\]: .* \"GET /backup HTTP/1.1\""
|
|
} -repeat 1 -start
|
|
|
|
haproxy h1 -conf {
|
|
defaults
|
|
mode http
|
|
option httplog
|
|
timeout connect "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
timeout client "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
timeout server "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
|
|
frontend fe1
|
|
bind "fd@${fe_1}"
|
|
log backend@mylog-tcp local0
|
|
log backend@mylog-udp local0
|
|
default_backend be
|
|
|
|
frontend fe2
|
|
bind "fd@${fe_2}"
|
|
log backend@mylog-failover local0
|
|
default_backend be
|
|
|
|
backend be
|
|
server app1 ${s1_addr}:${s1_port}
|
|
|
|
backend mylog-tcp
|
|
mode log
|
|
server s1 tcp@127.0.0.1:1514 #TCP: to log-forward
|
|
|
|
backend mylog-udp
|
|
mode log
|
|
|
|
# extract id (integer) from URL in the form "GET /id" and use it as hash key
|
|
balance log-hash 'field(-2,\"),field(2,/),field(1, )'
|
|
hash-type map-based none
|
|
|
|
server s1 udp@${Slg1_addr}:${Slg1_port} # syslog 1 only receives "GET /0" requests
|
|
server s2 udp@${Slg2_addr}:${Slg2_port} # syslog 2 only receives "GET /1" requests
|
|
|
|
log-forward syslog2udp
|
|
bind 127.0.0.1:1514
|
|
log backend@mylog-udp local0 # Back to UDP log backend
|
|
|
|
backend mylog-failover
|
|
mode log
|
|
balance sticky
|
|
|
|
server s1 udp@${Slg21_addr}:${Slg21_port} # only receives "GET /srv1" request
|
|
server s2 udp@${Slg22_addr}:${Slg22_port} # only receives "GET /srv2" request
|
|
server s3 udp@${Slg23_addr}:${Slg23_port} # only receives "GET /srv3" request
|
|
|
|
server s4 udp@${Slg24_addr}:${Slg24_port} backup # only receives "GET /backup" request
|
|
} -start
|
|
|
|
# Test log distribution reliability
|
|
|
|
# all logs should go to s1
|
|
client c1 -connect ${h1_fe_1_sock} {
|
|
txreq -url "/0"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -repeat 50 -start
|
|
|
|
# all logs should go to s2
|
|
client c2 -connect ${h1_fe_1_sock} {
|
|
txreq -url "/1"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -repeat 50 -start
|
|
|
|
syslog Slg1 -wait
|
|
syslog Slg2 -wait
|
|
|
|
# Test server queue/dequeue/failover mechanism
|
|
|
|
# s1 should handle this
|
|
client c21 -connect ${h1_fe_2_sock} {
|
|
txreq -url "/srv1"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -run
|
|
|
|
haproxy h1 -cli {
|
|
send "disable server mylog-failover/s1"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
# s2 should handle this
|
|
client c22 -connect ${h1_fe_2_sock} {
|
|
txreq -url "/srv2"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -run
|
|
|
|
haproxy h1 -cli {
|
|
send "disable server mylog-failover/s2"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
haproxy h1 -cli {
|
|
send "enable server mylog-failover/s1"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
# s3 should handle this
|
|
client c23 -connect ${h1_fe_2_sock} {
|
|
txreq -url "/srv3"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -run
|
|
|
|
haproxy h1 -cli {
|
|
send "disable server mylog-failover/s1"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
haproxy h1 -cli {
|
|
send "disable server mylog-failover/s3"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
# backup should handle this
|
|
client c24 -connect ${h1_fe_2_sock} {
|
|
txreq -url "/backup"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -run
|
|
|
|
haproxy h1 -cli {
|
|
send "enable server mylog-failover/s3"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
haproxy h1 -cli {
|
|
send "enable server mylog-failover/s2"
|
|
expect ~ ".*"
|
|
}
|
|
|
|
# s3 should handle this
|
|
client c25 -connect ${h1_fe_2_sock} {
|
|
txreq -url "/srv3"
|
|
rxresp
|
|
expect resp.status == 200
|
|
} -run
|
|
|
|
syslog Slg21 -wait
|
|
syslog Slg22 -wait
|
|
syslog Slg23 -wait
|
|
syslog Slg24 -wait
|