1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Fix HAProxy draining (#1993)

* Fix HAProxy draining by manually entering the 'MAINT' state

Inspired by rldleblanc: https://github.com/ansible/ansible/issues/37591#issuecomment-610130611

Signed-off-by: Norman Ziegner <norman.ziegner@ufz.de>

* Add changelog fragment

Signed-off-by: Norman Ziegner <norman.ziegner@ufz.de>

* Fix drain function docstring

Signed-off-by: Norman Ziegner <norman.ziegner@ufz.de>

* Fix typos

Signed-off-by: Norman Ziegner <norman.ziegner@ufz.de>

* Update changelog fragment

Signed-off-by: Norman Ziegner <norman.ziegner@ufz.de>
This commit is contained in:
Norman Ziegner 2021-04-07 19:29:10 +02:00 committed by GitHub
parent beb3b85a4f
commit 7145204594
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 7 deletions

View file

@ -0,0 +1,3 @@
---
bugfixes:
- haproxy - fix a bug preventing haproxy from properly entering ``DRAIN`` mode (https://github.com/ansible-collections/community.general/issues/1913).

View file

@ -367,10 +367,9 @@ class HAProxy(object):
# We can assume there will only be 1 element in state because both svname and pxname are always set when we get here # We can assume there will only be 1 element in state because both svname and pxname are always set when we get here
# When using track we get a status like this: MAINT (via pxname/svname) so we need to do substring matching # When using track we get a status like this: MAINT (via pxname/svname) so we need to do substring matching
if status in state[0]['status']: if status in state[0]['status']:
if not self._drain or (state[0]['scur'] == '0' and 'MAINT' in state): if not self._drain or state[0]['scur'] == '0':
return True return True
else: time.sleep(self.wait_interval)
time.sleep(self.wait_interval)
self.module.fail_json(msg="server %s/%s not status '%s' after %d retries. Aborting." % self.module.fail_json(msg="server %s/%s not status '%s' after %d retries. Aborting." %
(pxname, svname, status, self.wait_retries)) (pxname, svname, status, self.wait_retries))
@ -409,15 +408,17 @@ class HAProxy(object):
def drain(self, host, backend, status='DRAIN'): def drain(self, host, backend, status='DRAIN'):
""" """
Drain action, sets the server to DRAIN mode. Drain action, sets the server to DRAIN mode.
In this mode mode, the server will not accept any new connections In this mode, the server will not accept any new connections
other than those that are accepted via persistence. other than those that are accepted via persistence.
""" """
haproxy_version = self.discover_version() haproxy_version = self.discover_version()
# check if haproxy version suppots DRAIN state (starting with 1.5) # check if haproxy version supports DRAIN state (starting with 1.5)
if haproxy_version and (1, 5) <= haproxy_version: if haproxy_version and (1, 5) <= haproxy_version:
cmd = "set server $pxname/$svname state drain" cmd = "set server $pxname/$svname state drain"
self.execute_for_backends(cmd, backend, host, status) self.execute_for_backends(cmd, backend, host, "DRAIN")
if status == "MAINT":
self.disabled(host, backend, self.shutdown_sessions)
def act(self): def act(self):
""" """
@ -426,7 +427,7 @@ class HAProxy(object):
# Get the state before the run # Get the state before the run
self.command_results['state_before'] = self.get_state_for(self.backend, self.host) self.command_results['state_before'] = self.get_state_for(self.backend, self.host)
# toggle enable/disbale server # toggle enable/disable server
if self.state == 'enabled': if self.state == 'enabled':
self.enabled(self.host, self.backend, self.weight) self.enabled(self.host, self.backend, self.weight)
elif self.state == 'disabled' and self._drain: elif self.state == 'disabled' and self._drain: