diff --git a/swh/objstorage/api/server.py b/swh/objstorage/api/server.py --- a/swh/objstorage/api/server.py +++ b/swh/objstorage/api/server.py @@ -18,32 +18,50 @@ from swh.objstorage import get_objstorage from swh.objstorage.objstorage import DEFAULT_LIMIT from swh.objstorage.exc import ObjNotFoundError +from swh.core.statsd import statsd +def timed(f): + async def w(*a, **kw): + statsd.increment('swh_objstorage_%s_count' % (f.__name__)) + with statsd.timed( + 'swh_objstorage_%s_duration_seconds' % (f.__name__)): + return await(f(*a, **kw)) + return w + + +@timed async def index(request): return aiohttp.web.Response(body="SWH Objstorage API server") +@timed async def check_config(request): req = await decode_request(request) return encode_data(request.app['objstorage'].check_config(**req)) +@timed async def contains(request): req = await decode_request(request) return encode_data(request.app['objstorage'].__contains__(**req)) +@timed async def add_bytes(request): req = await decode_request(request) + statsd.increment('swh_objstorage_add_bytes_volume', + len(req['content'])) return encode_data(request.app['objstorage'].add(**req)) +@timed async def add_batch(request): req = await decode_request(request) return encode_data(request.app['objstorage'].add_batch(**req)) +@timed async def get_bytes(request): req = await decode_request(request) try: @@ -55,19 +73,24 @@ } return encode_data(ret, status=404) else: + statsd.increment('swh_objstorage_get_bytes_volume', + len(ret)) return encode_data(ret) +@timed async def get_batch(request): req = await decode_request(request) return encode_data(request.app['objstorage'].get_batch(**req)) +@timed async def check(request): req = await decode_request(request) return encode_data(request.app['objstorage'].check(**req)) +@timed async def delete(request): req = await decode_request(request) return encode_data(request.app['objstorage'].delete(**req)) @@ -75,6 +98,7 @@ # Management methods +@timed async def get_random_contents(request): req = await decode_request(request) return encode_data(request.app['objstorage'].get_random(**req)) @@ -82,6 +106,7 @@ # Streaming methods +@timed async def add_stream(request): hex_id = request.match_info['hex_id'] obj_id = hashutil.hash_to_bytes(hex_id) @@ -115,6 +140,7 @@ return encode_data(obj_id) +@timed async def get_stream(request): hex_id = request.match_info['hex_id'] obj_id = hashutil.hash_to_bytes(hex_id) @@ -126,6 +152,7 @@ return response +@timed async def list_content(request): last_obj_id = request.query.get('lastObjId') if last_obj_id: