summaryrefslogtreecommitdiff
path: root/cloudinit/DataSourceEc2.py
diff options
context:
space:
mode:
authorScott Moser <smoser@ubuntu.com>2011-02-07 13:09:42 -0500
committerScott Moser <smoser@ubuntu.com>2011-02-07 13:09:42 -0500
commit48564dc9cab705a675cc4751db13af158507e358 (patch)
tree91003a8a5ac173b4d50310521469a98bbe8464a3 /cloudinit/DataSourceEc2.py
parent53173904c3bf539097efa4a7d88223e75dd8d103 (diff)
downloadvyos-cloud-init-48564dc9cab705a675cc4751db13af158507e358.tar.gz
vyos-cloud-init-48564dc9cab705a675cc4751db13af158507e358.zip
make DataSourceEc2 configurable (timeout, retries), lower default retries
This lowers the default retries from 100 to 30 (1050 seconds to 105 seconds)
Diffstat (limited to 'cloudinit/DataSourceEc2.py')
-rw-r--r--cloudinit/DataSourceEc2.py22
1 files changed, 20 insertions, 2 deletions
diff --git a/cloudinit/DataSourceEc2.py b/cloudinit/DataSourceEc2.py
index 9c385c6c..9f1cf840 100644
--- a/cloudinit/DataSourceEc2.py
+++ b/cloudinit/DataSourceEc2.py
@@ -80,7 +80,25 @@ class DataSourceEc2(DataSource.DataSource):
return fallback
- def wait_for_metadata_service(self, sleeps = 100):
+ def wait_for_metadata_service(self, sleeps = None):
+ mcfg = self.ds_cfg
+ if sleeps is None:
+ sleeps = 30
+ try:
+ sleeps = int(mcfg.get("retries",sleeps))
+ except Exception as e:
+ util.logexc(log)
+ log.warn("Failed to get number of sleeps, using %s" % sleeps)
+
+ if sleeps == 0: return False
+
+ timeout=2
+ try:
+ timeout = int(mcfg.get("timeout",timeout))
+ except Exception as e:
+ util.logexc(log)
+ log.warn("Failed to get timeout, using %s" % timeout)
+
sleeptime = 1
address = '169.254.169.254'
starttime = time.time()
@@ -93,7 +111,7 @@ class DataSourceEc2(DataSource.DataSource):
reason = ""
try:
req = urllib2.Request(url)
- resp = urllib2.urlopen(req, timeout=2)
+ resp = urllib2.urlopen(req, timeout=timeout)
if resp.read() != "": return True
reason = "empty data [%s]" % resp.getcode()
except urllib2.HTTPError as e: