Merge pull request #1556 from coreos-inc/builder-cloudwatch

Add a cloud watch metric when we fail to start a build via EC2
This commit is contained in:
josephschorr 2016-06-20 13:51:28 -04:00 committed by GitHub
commit f3204daa0c

View file

@ -14,6 +14,7 @@ from functools import partial
from buildman.asyncutil import AsyncWrapper
from container_cloud_config import CloudConfigContext
from app import metric_queue
logger = logging.getLogger(__name__)
@ -136,6 +137,7 @@ class EC2Executor(BuilderExecutor):
)
interfaces = boto.ec2.networkinterface.NetworkInterfaceCollection(interface)
try:
reservation = yield From(ec2_conn.run_instances(
coreos_ami,
instance_type=self.executor_config['EC2_INSTANCE_TYPE'],
@ -145,6 +147,10 @@ class EC2Executor(BuilderExecutor):
block_device_map=block_devices,
network_interfaces=interfaces,
))
except boto.exception.EC2ResponseError as ec2e:
logger.exception('Unable to spawn builder instance')
metric_queue.put('EC2BuildStartFailure', 1, unit='Count')
raise ec2e
if not reservation.instances:
raise ExecutorException('Unable to spawn builder instance.')