Asynchronous cache manager designed for horizontally scaled web applications.
Project description
Introduction
Asynchronous cache manager designed for horizontally scaled web applications. NOTE: Currently has implementation only for FastAPI using Redis.
Requirements
Python 3.7+
Installation
$ pip install atomcache
---> 100%
Explanation schema
As UML
@startuml
!theme materia
participant Redis
participant Instance_A as A
participant Instance_B as B
participant Instance_N as C
B <-> Redis: GET: Cache=null & GET: Lock=null
B <-> Redis: SET: Lock = true
activate B #Red
A <--> Redis: GET: Cache=null & GET: Lock=true
activate A #Transparent
C <--> Redis: GET: Cache=null & GET: Lock=true
activate C #Transparent
B <--> B: Do the computation
B -> Redis: SET: Cache={...}
deactivate B
group Notify Cache SET
Redis -> C
Redis -> A
end
group GET Cache
Redis <-> C
deactivate C
Redis <-> A
deactivate A
end
@enduml
Examples:
Usage as FastAPI Dependency
- Create a file
events.py
with:
from typing import Optional, Callable
from redis.asyncio import Redis
from fastapi import FastAPI, Depends
from atomcache import Cache
def create_start_app_handler(app: FastAPI) -> Callable:
async def start_app() -> None:
redis: Redis = await Redis.from_url(url="redis://localhost", encoding="utf-8")
await Cache.init(app, redis)
return start_app
def create_stop_app_handler(app: FastAPI) -> Callable:
async def stop_app() -> None:
await Cache.backend.close()
return stop_app
- Create a file
main.py
with:
from typing import Optional
from fastapi import FastAPI, Depends
from atomcache import Cache
from .events import create_start_app_handler, create_stop_app_handler
app = FastAPI()
app.add_event_handler("startup", create_start_app_handler(app))
app.add_event_handler("shutdown", create_stop_app_handler(app))
@router.get("/resources", response_model=List[TheResponseModel], name="main:test-example")
async def resources(offset: int = 0, items: int = 10, cache: Cache = Depends(Cache(exp=600)):
cache_id = f"{offset}-{items}" # Build cache identifier
await cache.raise_try(cache_id) # Try to respond from cache
response = await db.find(TheResponseModel, skip=offset, limit=items)
await asyncio.sleep(10) # Do some heavy work for 10 sec, see `lock_timeout`
return cache.set(response, cache_id=cache_id)
Direct cache usage for avoiding repetitive calling on external resources:
from aiohttp import ClientSession
from atomcache import Cache
cache = Cache(exp=1200, namespace="my-namespace:")
async def requesting_helper(ref: str) -> List[dict]:
cached_value = await cache.get(cache_id=ref)
if cached_value is not None:
return cached_value
async with ClientSession() as session:
async with session.get(f"https://external-api.io/{ref}") as response:
if response.ok:
cached_value = response.json()
return cache.set(cached_value, cache_id=ref)
return []
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
atomcache-0.7.6.tar.gz
(9.1 kB
view details)
Built Distribution
File details
Details for the file atomcache-0.7.6.tar.gz
.
File metadata
- Download URL: atomcache-0.7.6.tar.gz
- Upload date:
- Size: 9.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.0 CPython/3.11.6 Linux/6.5.0-26-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b58eb29626644a51c227990e62df33633a8b9049e5a5efd4c75c6c6c79be0c05 |
|
MD5 | 6aa4bdd3778ae8e4b54204098edb6530 |
|
BLAKE2b-256 | 7aa55703c4ed070a79bb600f90c9fba5ebdae76c5988ec6053b9f950a8c99f59 |
File details
Details for the file atomcache-0.7.6-py3-none-any.whl
.
File metadata
- Download URL: atomcache-0.7.6-py3-none-any.whl
- Upload date:
- Size: 9.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.0 CPython/3.11.6 Linux/6.5.0-26-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 05afefd68b2e69590fbb59f236153c1ba8d6c32e87f657f1bb62cc6352ecb4b8 |
|
MD5 | 26c59700d14de1e10095b9fde65d8c22 |
|
BLAKE2b-256 | 8d4d5d8e1f66697cefc2a6c89c88ac12b63b8b1b714c230bdbb3ec58a6b6af90 |