A cache system for aiohttp server
Project description
Aiohttp-cache
What's aiohttp-cache
aiohttp-cache is a plugin for aiohttp.web server that allow to use a
cache system to improve the performance of your site.
How to use it
With in-memory backend
import asyncio
from aiohttp import web
from aiohttp_cache import ( # noqa
setup_cache,
cache,
)
PAYLOAD = {"hello": "aiohttp_cache"}
WAIT_TIME = 2
@cache()
async def some_long_running_view(request: web.Request) -> web.Response:
await asyncio.sleep(WAIT_TIME)
payload = await request.json()
return web.json_response(payload)
app = web.Application()
setup_cache(app)
app.router.add_post("/", some_long_running_view)
web.run_app(app)
With redis backend
Note: redis should be available at
$CACHE_URL env variable orredis://localhost:6379/0
import asyncio
import yarl
from aiohttp import web
from envparse import env
from aiohttp_cache import ( # noqa
setup_cache,
cache,
RedisConfig,
)
PAYLOAD = {"hello": "aiohttp_cache"}
WAIT_TIME = 2
@cache()
async def some_long_running_view(request: web.Request) -> web.Response:
await asyncio.sleep(WAIT_TIME)
payload = await request.json()
return web.json_response(payload)
app = web.Application()
url = yarl.URL(env.str("CACHE_URL", default="redis://localhost:6379/0"))
setup_cache(
app,
cache_type="redis",
backend_config=RedisConfig(
db=int(url.path[1:]), host=url.host, port=url.port
),
)
app.router.add_post("/", some_long_running_view)
web.run_app(app)
Example with a custom cache key
Let's say you would like to cache the requests just by the method and json payload, then you can setup this as per the follwing example.
Note default key_pattern is:
DEFAULT_KEY_PATTERN = (
AvailableKeys.method,
AvailableKeys.host,
AvailableKeys.path,
AvailableKeys.postdata,
AvailableKeys.ctype,
)
import asyncio
from aiohttp import web
from aiohttp_cache import setup_cache, cache, AvailableKeys # noqa
PAYLOAD = {"hello": "aiohttp_cache"}
WAIT_TIME = 2
@cache()
async def some_long_running_view(request: web.Request) -> web.Response:
await asyncio.sleep(WAIT_TIME)
payload = await request.json()
return web.json_response(payload)
custom_cache_key = (AvailableKeys.method, AvailableKeys.json)
app = web.Application()
setup_cache(app, key_pattern=custom_cache_key)
app.router.add_post("/", some_long_running_view)
web.run_app(app)
License
This project is released under BSD license. Feel free
Source Code
The latest developer version is available in a github repository: https://github.com/cr0hn/aiohttp-cache
Development environment
- docker-compose run tests
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aiohttp-cache-2.0.2.tar.gz.
File metadata
- Download URL: aiohttp-cache-2.0.2.tar.gz
- Upload date:
- Size: 6.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.19.78-coreos
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8af187b4879aeb82bed8216cfbf582cf8a02c3ddfd0c7da2b8b2b55ff792be85
|
|
| MD5 |
8c7beb3e94f1ce8285e8739686e398c9
|
|
| BLAKE2b-256 |
0c1f2a421db83bd60a232f4a9f27fc1aedc028c79d67ddd2084bd27ef5187213
|
File details
Details for the file aiohttp_cache-2.0.2-py3-none-any.whl.
File metadata
- Download URL: aiohttp_cache-2.0.2-py3-none-any.whl
- Upload date:
- Size: 7.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/4.19.78-coreos
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
953868d324ec571e2fd9eab599e14ad7b996b3749b30a769a7f8d95ae2675ac0
|
|
| MD5 |
3019597b92ccb85241d0a0fa2466f022
|
|
| BLAKE2b-256 |
d42f4fd76ed24cd498afe821be23a55ab5d02cb9dba7ad0270a1094c55c124de
|