Fix weighted round-robin about UDP and SCTP listener

'lb_algo rr' in keepalived won't work correctly with weight
for UDP and SCTP listeners, it should be 'lb_algo wrr'.

'wrr' is superset of 'rr' algorithm, as round-robin is
a specical instance of the weighted round-robin scheduling,
in which all the weights are equal. [1]

Algorithm in HAProxy is set to 'roundrobin', which also support
weights, but in keepalived must be set to 'wrr' to work with
the weighted round-robin scheduling, as it is different to 'rr'.

[1] https://www.keepalived.org/doc/scheduling_algorithms.html

Story 2008462
Task 41491

Change-Id: Ic63929d8864e5285baf70dd85e6362988bf2863f
This commit is contained in:
Xing Zhang 2021-03-02 12:55:35 +08:00
parent c93a76b9f3
commit 5352a10f62
No known key found for this signature in database
GPG Key ID: 43F80E57B910E3B0
4 changed files with 25 additions and 19 deletions

View File

@ -30,7 +30,7 @@ PROTOCOL_MAP = {
} }
BALANCE_MAP = { BALANCE_MAP = {
constants.LB_ALGORITHM_ROUND_ROBIN: 'rr', constants.LB_ALGORITHM_ROUND_ROBIN: 'wrr',
constants.LB_ALGORITHM_LEAST_CONNECTIONS: 'lc', constants.LB_ALGORITHM_LEAST_CONNECTIONS: 'lc',
constants.LB_ALGORITHM_SOURCE_IP: 'sh' constants.LB_ALGORITHM_SOURCE_IP: 'sh'
} }

View File

@ -42,7 +42,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" persistence_timeout 33\n" " persistence_timeout 33\n"
@ -88,7 +88,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -131,7 +131,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -174,7 +174,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -229,7 +229,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n\n\n" " protocol UDP\n\n\n"
" # Configuration for Pool sample_pool_id_0\n" " # Configuration for Pool sample_pool_id_0\n"
@ -247,7 +247,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n\n\n" " protocol UDP\n\n\n"
" # Pool sample_pool_id_1 is disabled\n" " # Pool sample_pool_id_1 is disabled\n"
@ -358,7 +358,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -419,7 +419,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol UDP\n" " protocol UDP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -477,7 +477,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" persistence_timeout 33\n" " persistence_timeout 33\n"
@ -523,7 +523,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -566,7 +566,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -609,7 +609,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -749,7 +749,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" delay_loop 30\n" " delay_loop 30\n"
@ -810,7 +810,7 @@ class TestLvsCfg(base.TestCase):
"# Configuration for Listener sample_listener_id_1\n\n" "# Configuration for Listener sample_listener_id_1\n\n"
"net_namespace amphora-haproxy\n\n" "net_namespace amphora-haproxy\n\n"
"virtual_server 10.0.0.2 80 {\n" "virtual_server 10.0.0.2 80 {\n"
" lb_algo rr\n" " lb_algo wrr\n"
" lb_kind NAT\n" " lb_kind NAT\n"
" protocol SCTP\n" " protocol SCTP\n"
" delay_loop 30\n" " delay_loop 30\n"

View File

@ -461,7 +461,7 @@ RET_UDP_POOL = {
'id': 'sample_pool_id_1', 'id': 'sample_pool_id_1',
'enabled': True, 'enabled': True,
'health_monitor': RET_UDP_HEALTH_MONITOR, 'health_monitor': RET_UDP_HEALTH_MONITOR,
'lb_algorithm': 'rr', 'lb_algorithm': 'wrr',
'members': [UDP_MEMBER_1, UDP_MEMBER_2], 'members': [UDP_MEMBER_1, UDP_MEMBER_2],
'protocol': 'udp', 'protocol': 'udp',
'session_persistence': UDP_SOURCE_IP_BODY 'session_persistence': UDP_SOURCE_IP_BODY
@ -473,7 +473,7 @@ RET_UDP_LISTENER = {
'id': 'sample_pool_id_1', 'id': 'sample_pool_id_1',
'enabled': True, 'enabled': True,
'health_monitor': RET_UDP_HEALTH_MONITOR, 'health_monitor': RET_UDP_HEALTH_MONITOR,
'lb_algorithm': 'rr', 'lb_algorithm': 'wrr',
'members': [UDP_MEMBER_1, UDP_MEMBER_2], 'members': [UDP_MEMBER_1, UDP_MEMBER_2],
'protocol': 'udp', 'protocol': 'udp',
'session_persistence': UDP_SOURCE_IP_BODY 'session_persistence': UDP_SOURCE_IP_BODY
@ -544,7 +544,7 @@ RET_SCTP_POOL = {
'id': 'sample_pool_id_1', 'id': 'sample_pool_id_1',
'enabled': True, 'enabled': True,
'health_monitor': RET_SCTP_HEALTH_MONITOR, 'health_monitor': RET_SCTP_HEALTH_MONITOR,
'lb_algorithm': 'rr', 'lb_algorithm': 'wrr',
'members': [SCTP_MEMBER_1, SCTP_MEMBER_2], 'members': [SCTP_MEMBER_1, SCTP_MEMBER_2],
'protocol': 'sctp', 'protocol': 'sctp',
'session_persistence': SCTP_SOURCE_IP_BODY 'session_persistence': SCTP_SOURCE_IP_BODY
@ -556,7 +556,7 @@ RET_SCTP_LISTENER = {
'id': 'sample_pool_id_1', 'id': 'sample_pool_id_1',
'enabled': True, 'enabled': True,
'health_monitor': RET_SCTP_HEALTH_MONITOR, 'health_monitor': RET_SCTP_HEALTH_MONITOR,
'lb_algorithm': 'rr', 'lb_algorithm': 'wrr',
'members': [SCTP_MEMBER_1, SCTP_MEMBER_2], 'members': [SCTP_MEMBER_1, SCTP_MEMBER_2],
'protocol': 'sctp', 'protocol': 'sctp',
'session_persistence': SCTP_SOURCE_IP_BODY 'session_persistence': SCTP_SOURCE_IP_BODY

View File

@ -0,0 +1,6 @@
---
fixes:
- |
Fix weighted round-robin for UDP and SCTP listeners with keepalived and
lvs. The algorithm must be specified as 'wrr' in order for weighted
round-robin to work correctly, but was being set to 'rr'.