From 7c5b4b142a67f6c741d9629db140ea0d581bc33f Mon Sep 17 00:00:00 2001 From: Ashwanth Kumar Date: Fri, 5 Feb 2016 13:27:55 +0530 Subject: [PATCH] Doing exponential backoff on route53 upon AWS throttling --- lib/ansible/modules/cloud/amazon/route53.py | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/ansible/modules/cloud/amazon/route53.py b/lib/ansible/modules/cloud/amazon/route53.py index cda00902db..ffef46ee64 100644 --- a/lib/ansible/modules/cloud/amazon/route53.py +++ b/lib/ansible/modules/cloud/amazon/route53.py @@ -345,6 +345,21 @@ def commit(changes, retry_interval, wait, wait_timeout): raise TimeoutError() return result +# Shamelessly copied over from https://git.io/vgmDG +IGNORE_CODE = 'Throttling' +MAX_RETRIES=5 +def invoke_with_throttling_retries(function_ref, *argv): + retries=0 + while True: + try: + retval=function_ref(*argv) + return retval + except boto.exception.BotoServerError, e: + if e.code != IGNORE_CODE or retries==MAX_RETRIES: + raise e + time.sleep(5 * (2**retries)) + retries += 1 + def main(): argument_spec = ec2_argument_spec() argument_spec.update(dict( @@ -530,7 +545,7 @@ def main(): changes.add_change_record(command, wanted_rset) try: - result = commit(changes, retry_interval_in, wait_in, wait_timeout_in) + result = invoke_with_throttling_retries(commit, changes, retry_interval_in, wait_in, wait_timeout_in) except boto.route53.exception.DNSServerError, e: txt = e.body.split("")[1] txt = txt.split("")[0]