From 46a197c76e2f10ea40604f9907c3cdb59ed58a81 Mon Sep 17 00:00:00 2001 From: Stanislav Bushuev Date: Wed, 18 May 2022 14:48:54 +0200 Subject: [PATCH] Use aiojobs for background tasks --- aiocache/decorators.py | 11 ++++++----- requirements-dev.txt | 1 + setup.py | 1 + 3 files changed, 8 insertions(+), 5 deletions(-) diff --git a/aiocache/decorators.py b/aiocache/decorators.py index 202a45cc..6d4aab23 100644 --- a/aiocache/decorators.py +++ b/aiocache/decorators.py @@ -3,12 +3,16 @@ import inspect import logging +import aiojobs + from aiocache.base import SENTINEL from aiocache.factory import Cache, caches from aiocache.lock import RedLock logger = logging.getLogger(__name__) +loop = asyncio.get_event_loop() +scheduler = loop.run_until_complete(aiojobs.create_scheduler(pending_limit=0, limit=None)) class cached: @@ -112,9 +116,7 @@ async def decorator( if aiocache_wait_for_write: await self.set_in_cache(key, result) else: - # TODO: Use aiojobs to avoid warnings. - asyncio.create_task(self.set_in_cache(key, result)) - + await scheduler.spawn(self.set_in_cache(key, result)) return result def get_cache_key(self, f, args, kwargs): @@ -336,8 +338,7 @@ async def decorator( if aiocache_wait_for_write: await self.set_in_cache(result, f, args, kwargs) else: - # TODO: Use aiojobs to avoid warnings. - asyncio.create_task(self.set_in_cache(result, f, args, kwargs)) + await scheduler.spawn(self.set_in_cache(result, f, args, kwargs)) return result diff --git a/requirements-dev.txt b/requirements-dev.txt index 591677bf..73bc49f1 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -1,4 +1,5 @@ -e .[dev,redis,memcached,msgpack] +aiojobs==1.0.0 aiohttp==3.8.1 flake8==4.0.1 flake8-bandit==3.0.0 diff --git a/setup.py b/setup.py index 889e5434..4a940ab1 100644 --- a/setup.py +++ b/setup.py @@ -38,6 +38,7 @@ 'redis:python_version>="3.8"': ["aioredis>=1.3.0,<2.0"], "memcached": ["aiomcache>=0.5.2"], "msgpack": ["msgpack>=0.5.5"], + "aiojobs": ["aiojobs>=1.0.0"], }, include_package_data=True, )