forked from p15670423/monkey
Catch exceptions in AwsInstance and AzureInstance
This commit is contained in:
parent
13af101c2a
commit
59383e7946
|
@ -45,7 +45,7 @@ class AwsInstance(CloudInstance):
|
||||||
self.account_id = self._extract_account_id(
|
self.account_id = self._extract_account_id(
|
||||||
urllib.request.urlopen(
|
urllib.request.urlopen(
|
||||||
AWS_LATEST_METADATA_URI_PREFIX + 'dynamic/instance-identity/document', timeout=2).read().decode())
|
AWS_LATEST_METADATA_URI_PREFIX + 'dynamic/instance-identity/document', timeout=2).read().decode())
|
||||||
except (urllib.error.URLError, IOError) as e:
|
except (urllib.error.URLError, json.decoder.JSONDecodeError, IOError) as e:
|
||||||
logger.debug("Failed init of AwsInstance while getting dynamic instance data: {}".format(e))
|
logger.debug("Failed init of AwsInstance while getting dynamic instance data: {}".format(e))
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
|
import simplejson
|
||||||
|
|
||||||
from common.cloud.environment_names import Environment
|
from common.cloud.environment_names import Environment
|
||||||
from common.cloud.instance import CloudInstance
|
from common.cloud.instance import CloudInstance
|
||||||
|
@ -41,10 +42,10 @@ class AzureInstance(CloudInstance):
|
||||||
# If not on cloud, the metadata URL is non-routable and the connection will fail.
|
# If not on cloud, the metadata URL is non-routable and the connection will fail.
|
||||||
# If on AWS, should get 404 since the metadata service URL is different, so bool(response) will be false.
|
# If on AWS, should get 404 since the metadata service URL is different, so bool(response) will be false.
|
||||||
if response:
|
if response:
|
||||||
logger.debug("On Azure. Trying to parse metadata.")
|
logger.debug("Trying to parse Azure metadata.")
|
||||||
self.try_parse_response(response)
|
self.try_parse_response(response)
|
||||||
else:
|
else:
|
||||||
logger.warning("On Azure, but metadata response not ok: {}".format(response.status_code))
|
logger.warning(f"On Azure, but metadata response not ok: {response.status_code}")
|
||||||
except requests.RequestException:
|
except requests.RequestException:
|
||||||
logger.debug("Failed to get response from Azure metadata service: This instance is not on Azure.")
|
logger.debug("Failed to get response from Azure metadata service: This instance is not on Azure.")
|
||||||
self.on_azure = False
|
self.on_azure = False
|
||||||
|
@ -55,5 +56,5 @@ class AzureInstance(CloudInstance):
|
||||||
self.instance_name = response_data["compute"]["name"]
|
self.instance_name = response_data["compute"]["name"]
|
||||||
self.instance_id = response_data["compute"]["vmId"]
|
self.instance_id = response_data["compute"]["vmId"]
|
||||||
self.location = response_data["compute"]["location"]
|
self.location = response_data["compute"]["location"]
|
||||||
except KeyError:
|
except (KeyError, simplejson.errors.JSONDecodeError) as e:
|
||||||
logger.exception("Error while parsing response from Azure metadata service.")
|
logger.exception(f"Error while parsing response from Azure metadata service: {e}")
|
||||||
|
|
Loading…
Reference in New Issue