X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/19c20b239f9d88f6fd4dab542524143f24cc8536..2024ca087c3b9c99ebb792011b60fecdf1486467:/sdk/python/arvados/keep.py diff --git a/sdk/python/arvados/keep.py b/sdk/python/arvados/keep.py index fdb27f0d31..b5d5d72503 100644 --- a/sdk/python/arvados/keep.py +++ b/sdk/python/arvados/keep.py @@ -21,6 +21,7 @@ import timer import datetime import ssl +_logger = logging.getLogger('arvados.keep') global_client_object = None from api import * @@ -200,10 +201,10 @@ class KeepClient(object): self.run_with_limiter(limiter) def run_with_limiter(self, limiter): - logging.debug("KeepWriterThread %s proceeding %s %s" % - (str(threading.current_thread()), - self.args['data_hash'], - self.args['service_root'])) + _logger.debug("KeepWriterThread %s proceeding %s %s", + str(threading.current_thread()), + self.args['data_hash'], + self.args['service_root']) h = httplib2.Http(timeout=self.args.get('timeout', None)) url = self.args['service_root'] + self.args['data_hash'] api_token = config.get('ARVADOS_API_TOKEN') @@ -215,7 +216,7 @@ class KeepClient(object): headers['X-Keep-Desired-Replication'] = str(self.args['want_copies']) try: - logging.debug("Uploading to {}".format(url)) + _logger.debug("Uploading to {}".format(url)) resp, content = h.request(url.encode('utf-8'), 'PUT', headers=headers, body=self.args['data']) @@ -230,10 +231,10 @@ class KeepClient(object): body=body) if re.match(r'^2\d\d$', resp['status']): self._success = True - logging.debug("KeepWriterThread %s succeeded %s %s" % - (str(threading.current_thread()), - self.args['data_hash'], - self.args['service_root'])) + _logger.debug("KeepWriterThread %s succeeded %s %s", + str(threading.current_thread()), + self.args['data_hash'], + self.args['service_root']) replicas_stored = 1 if 'x-keep-replicas-stored' in resp: # Tick the 'done' counter for the number of replica @@ -246,15 +247,15 @@ class KeepClient(object): pass limiter.save_response(content.strip(), replicas_stored) else: - logging.warning("Request fail: PUT %s => %s %s" % - (url, resp['status'], content)) + _logger.warning("Request fail: PUT %s => %s %s", + url, resp['status'], content) except (httplib2.HttpLib2Error, httplib.HTTPException, ssl.SSLError) as e: # When using https, timeouts look like ssl.SSLError from here. # "SSLError: The write operation timed out" - logging.warning("Request fail: PUT %s => %s: %s" % - (url, type(e), str(e))) + _logger.warning("Request fail: PUT %s => %s: %s", + url, type(e), str(e)) def __init__(self, **kwargs): self.lock = threading.Lock() @@ -298,7 +299,7 @@ class KeepClient(object): f['service_port'])) for f in keep_services) self.service_roots = sorted(set(roots)) - logging.debug(str(self.service_roots)) + _logger.debug(str(self.service_roots)) finally: self.lock.release() @@ -343,7 +344,7 @@ class KeepClient(object): # Remove the digits just used from the seed seed = seed[8:] - logging.debug(str(pseq)) + _logger.debug(str(pseq)) return pseq class CacheSlot(object): @@ -401,8 +402,6 @@ class KeepClient(object): self._cache_lock.release() def get(self, locator): - #logging.debug("Keep.get %s" % (locator)) - if re.search(r',', locator): return ''.join(self.get(x) for x in locator.split(',')) if 'KEEP_LOCAL_STORE' in os.environ: @@ -410,7 +409,6 @@ class KeepClient(object): expect_hash = re.sub(r'\+.*', '', locator) slot, first = self.reserve_cache(expect_hash) - #logging.debug("%s %s %s" % (slot, first, expect_hash)) if not first: v = slot.get() @@ -448,23 +446,23 @@ class KeepClient(object): def get_url(self, url, headers, expect_hash): h = httplib2.Http() try: - logging.info("Request: GET %s" % (url)) + _logger.info("Request: GET %s", url) with timer.Timer() as t: resp, content = h.request(url.encode('utf-8'), 'GET', headers=headers) - logging.info("Received %s bytes in %s msec (%s MiB/sec)" % (len(content), - t.msecs, - (len(content)/(1024*1024))/t.secs)) + _logger.info("Received %s bytes in %s msec (%s MiB/sec)", + len(content), t.msecs, + (len(content)/(1024*1024))/t.secs) if re.match(r'^2\d\d$', resp['status']): m = hashlib.new('md5') m.update(content) md5 = m.hexdigest() if md5 == expect_hash: return content - logging.warning("Checksum fail: md5(%s) = %s" % (url, md5)) + _logger.warning("Checksum fail: md5(%s) = %s", url, md5) except Exception as e: - logging.info("Request fail: GET %s => %s: %s" % - (url, type(e), str(e))) + _logger.info("Request fail: GET %s => %s: %s", + url, type(e), str(e)) return None def put(self, data, **kwargs): @@ -498,9 +496,9 @@ class KeepClient(object): threads_retry = [] for t in threads: if not t.success(): - logging.warning("Retrying: PUT %s %s" % ( - t.args['service_root'], - t.args['data_hash'])) + _logger.warning("Retrying: PUT %s %s", + t.args['service_root'], + t.args['data_hash']) retry_with_args = t.args.copy() t_retry = KeepClient.KeepWriterThread(**retry_with_args) t_retry.start()