Skip to content

Commit

Permalink
Add delay parameter
Browse files Browse the repository at this point in the history
We've seen issues in the past with nfs servers that would not release locks fast enough for evacuation to complete (see https://bugzilla.redhat.com/show_bug.cgi?id=1755760 for example).
This commit adds a DELAY parameter so we can wait for a certain amount of time before starting the evacuation.

We also take the chance to fix a couple of typos.
  • Loading branch information
lmiccini committed Oct 23, 2024
1 parent 1aded24 commit 02c351d
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,9 @@ spec:
kind: DNSMasq
name: dnsmasqs.network.openstack.org
version: v1beta1
- description: InstanceHA is the Schema for the instancehas API
displayName: Instance HA
kind: InstanceHA
- description: InstanceHa is the Schema for the instancehas API
displayName: Instance Ha
kind: InstanceHa
name: instancehas.instanceha.openstack.org
version: v1beta1
- description: IPSet is the Schema for the ipsets API
Expand Down
6 changes: 5 additions & 1 deletion templates/instanceha/bin/instanceha.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ def start_health_check_server():
TAGGED_IMAGES = config["TAGGED_IMAGES"] if 'TAGGED_IMAGES' in config else "true"
TAGGED_FLAVORS = config["TAGGED_FLAVORS"] if 'TAGGED_FLAVORS' in config else "true"
DELTA = int(config["DELTA"]) if 'DELTA' in config else 30
DELAY = int(config["DELAY"]) if 'DELAY' in config else 0
POLL = int(config["POLL"]) if 'POLL' in config else 45
THRESHOLD = int(config["THRESHOLD"]) if 'THRESHOLD' in config else 50
WORKERS = int(config["WORKERS"]) if 'WORKERS' in config else 4
Expand Down Expand Up @@ -182,6 +183,9 @@ def _host_evacuate(connection, host):
logging.info("Nothing to evacuate")
return True

# sleep for DELAY, this could be useful if nfs is in use and locks need to be released
time.sleep(DELAY)

# if SMART_EVACUATION is 'True' (string) use a ThreadPoolExecutor to poll the evacuation status
# otherwise use the old "fire and forget" approach
if 'true' in SMART_EVACUATION.lower():
Expand Down Expand Up @@ -865,7 +869,7 @@ def main():
with concurrent.futures.ThreadPoolExecutor() as executor:
results = list(executor.map(lambda service: process_service(service, reserved_hosts, True), to_resume))
if not all(results):
logging.warning('Some services failed to evacuate. Retrying in 30 seconds.')
logging.warning('Some services failed to evacuate. Retrying in %s seconds.' % POLL)

else:
logging.info('InstanceHa DISABLE is true, not evacuating')
Expand Down
1 change: 1 addition & 0 deletions templates/instanceha/config/config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ config:
TAGGED_FLAVORS: "true"
SMART_EVACUATION: "false"
DELTA: "30"
DELAY: "0"
POLL: "45"
THRESHOLD: "50"
WORKERS: "4"
Expand Down

0 comments on commit 02c351d

Please sign in to comment.