Use the new kwargs_from_env so that we can test with boot2docker and fix the issue with the .history call.

This commit is contained in:
Joseph Schorr 2014-11-24 20:28:48 -05:00
parent 716d7a737b
commit b2a0e58756

View file

@ -13,6 +13,7 @@ import shutil
import tarfile import tarfile
from docker import Client from docker import Client
from docker.utils import kwargs_from_env
from docker.errors import APIError from docker.errors import APIError
from tempfile import TemporaryFile, mkdtemp from tempfile import TemporaryFile, mkdtemp
from zipfile import ZipFile from zipfile import ZipFile
@ -38,7 +39,12 @@ TIMEOUT_PERIOD_MINUTES = 20
CACHE_EXPIRATION_PERIOD_HOURS = 24 CACHE_EXPIRATION_PERIOD_HOURS = 24
NO_TAGS = ['<none>:<none>'] NO_TAGS = ['<none>:<none>']
RESERVATION_TIME = (TIMEOUT_PERIOD_MINUTES + 5) * 60 RESERVATION_TIME = (TIMEOUT_PERIOD_MINUTES + 5) * 60
DOCKER_BASE_URL = os.environ.get('DOCKER_HOST', None)
def build_docker_args():
args = kwargs_from_env()
if 'tls' in args and os.environ.get('IGNORE_TLS_ISSUES', False):
args['tls'].verify = False
return args
def matches_system_error(status_str): def matches_system_error(status_str):
@ -130,8 +136,8 @@ class DockerfileBuildContext(object):
# Note: We have two different clients here because we (potentially) login # Note: We have two different clients here because we (potentially) login
# with both, but with different credentials that we do not want shared between # with both, but with different credentials that we do not want shared between
# the build and push operations. # the build and push operations.
self._push_cl = StreamingDockerClient(timeout=1200, base_url=DOCKER_BASE_URL) self._push_cl = StreamingDockerClient(timeout=1200, **build_docker_args())
self._build_cl = StreamingDockerClient(timeout=1200, base_url=DOCKER_BASE_URL) self._build_cl = StreamingDockerClient(timeout=1200, **build_docker_args())
dockerfile_path = os.path.join(self._build_dir, dockerfile_subdir, dockerfile_path = os.path.join(self._build_dir, dockerfile_subdir,
'Dockerfile') 'Dockerfile')
@ -337,7 +343,7 @@ class DockerfileBuildContext(object):
logger.debug('Tagging image %s as %s:%s', built_image, self._repo, tag) logger.debug('Tagging image %s as %s:%s', built_image, self._repo, tag)
self._push_cl.tag(built_image, self._repo, tag) self._push_cl.tag(built_image, self._repo, tag)
history = json.loads(self._push_cl.history(built_image)) history = self._push_cl.history(built_image)
num_images = len(history) num_images = len(history)
logger.debug('Pushing to repo %s', self._repo) logger.debug('Pushing to repo %s', self._repo)
@ -480,7 +486,7 @@ class DockerfileBuildWorker(Worker):
def watchdog(self): def watchdog(self):
logger.debug('Running build watchdog code.') logger.debug('Running build watchdog code.')
try: try:
docker_cl = Client(base_url=DOCKER_BASE_URL) docker_cl = Client(**build_docker_args())
# Iterate the running containers and kill ones that have been running more than 20 minutes # Iterate the running containers and kill ones that have been running more than 20 minutes
for container in docker_cl.containers(): for container in docker_cl.containers():
@ -493,6 +499,7 @@ class DockerfileBuildWorker(Worker):
self._timeout.set() self._timeout.set()
except ConnectionError as exc: except ConnectionError as exc:
logger.exception('Watchdog exception')
raise WorkerUnhealthyException(exc.message) raise WorkerUnhealthyException(exc.message)
def process_queue_item(self, job_details): def process_queue_item(self, job_details):
@ -525,9 +532,10 @@ class DockerfileBuildWorker(Worker):
# Lookup and save the version of docker being used. # Lookup and save the version of docker being used.
try: try:
docker_cl = Client(base_url=DOCKER_BASE_URL) docker_cl = Client(**build_docker_args())
docker_version = docker_cl.version().get('Version', '') docker_version = docker_cl.version().get('Version', '')
except ConnectionError as exc: except ConnectionError as exc:
logger.exception('Initial connection exception')
raise WorkerUnhealthyException(exc.message) raise WorkerUnhealthyException(exc.message)
dash = docker_version.find('-') dash = docker_version.find('-')
@ -664,6 +672,7 @@ class DockerfileBuildWorker(Worker):
except ConnectionError as exc: except ConnectionError as exc:
# A connection exception means the worker has become unhealthy (Docker is down) # A connection exception means the worker has become unhealthy (Docker is down)
# so we re-raise as that exception. # so we re-raise as that exception.
logger.exception('Build connection exception')
log_appender('Docker daemon has gone away. Will retry shortly.', build_logs.ERROR) log_appender('Docker daemon has gone away. Will retry shortly.', build_logs.ERROR)
raise WorkerUnhealthyException(exc.message) raise WorkerUnhealthyException(exc.message)