一个框架无关的Python缓存库,支持多种后端和框架集成。
- 🚀 框架无关: 可以与任何Python框架集成,不仅限于FastAPI
- 🔧 多后端支持: 支持Redis、Memcached、DynamoDB和内存缓存
- 🎯 类型安全: 完整的类型注解支持
- 🔄 异步优先: 原生异步支持,同时兼容同步函数
- 🎨 灵活配置: 支持自定义编码器、键构建器和过期策略
- 📦 向后兼容: 与fastapi-cache完全兼容
# 基础安装
pip install use-cache
# 安装Redis支持
pip install use-cache[redis]
# 安装Memcached支持
pip install use-cache[memcached]
# 安装DynamoDB支持
pip install use-cache[dynamodb]
# 安装所有后端
pip install use-cache[all]import asyncio
from use_cache import CacheManager, InMemoryBackend, JsonCoder
async def main():
# 初始化缓存管理器
cache_manager = CacheManager()
await cache_manager.init(
backend=InMemoryBackend(),
coder=JsonCoder(),
prefix="myapp:",
expire=300 # 5分钟
)
# 手动缓存操作
await cache_manager.set("user:123", {"name": "Alice", "age": 30})
user = await cache_manager.get("user:123")
print(user) # {'name': 'Alice', 'age': 30}
asyncio.run(main())from use_cache import cache, CacheManager, InMemoryBackend, JsonCoder
# 初始化缓存(通常在应用启动时)
async def setup_cache():
cache_manager = CacheManager()
await cache_manager.init(
backend=InMemoryBackend(),
coder=JsonCoder()
)
@cache(expire=60)
async def get_user_data(user_id: int):
# 模拟数据库查询
return {"id": user_id, "name": f"User {user_id}"}
# 使用
await setup_cache()
user = await get_user_data(123) # 第一次调用,执行函数
user = await get_user_data(123) # 第二次调用,使用缓存from fastapi import FastAPI
from use_cache import CacheManager, InMemoryBackend, JsonCoder
from use_cache.integrations.fastapi import cache
app = FastAPI()
@asynccontextmanager
async def lifespan(app: FastAPI):
# Initialize cache on startup
CacheManager.init(
backend=InMemoryBackend(),
coder=JsonCoder,
prefix="fastapi:",
expire=300 # 5 minutes
)
yield
# Cleanup on shutdown (if needed)
@app.get("/users/{user_id}")
@cache(expire=60)
async def get_user(user_id: int):
return {"id": user_id, "name": f"User {user_id}"}from use_cache import InMemoryBackend
backend = InMemoryBackend()from use_cache import RedisBackend
# 单个Redis实例
backend = RedisBackend("redis://localhost:6379")
# Redis集群
backend = RedisBackend([
"redis://node1:6379",
"redis://node2:6379",
"redis://node3:6379"
])from use_cache import MemcachedBackend
backend = MemcachedBackend("127.0.0.1", 11211)from use_cache import DynamoDBBackend
backend = DynamoDBBackend(
table_name="cache_table",
region_name="us-east-1"
)from use_cache import JsonCoder
coder = JsonCoder()from use_cache import PickleCoder
coder = PickleCoder()from use_cache import StringCoder
coder = StringCoder()from use_cache import default_key_builder
# 自动根据函数名和参数生成键from use_cache import simple_key_builder
# 仅使用函数名作为键def custom_key_builder(func, *args, **kwargs):
return f"custom:{func.__name__}:{hash(str(args) + str(kwargs))}"from use_cache import cache_one_minute, cache_one_hour, cache_one_day
@cache_one_minute
async def quick_data():
return "cached for 1 minute"
@cache_one_hour
async def hourly_data():
return "cached for 1 hour"
@cache_one_day
async def daily_data():
return "cached for 1 day"uv sync --extra test
# 如需安装后端支持,可选择性同步对应 extras:
# Redis: uv sync --extra redis
# Memcached: uv sync --extra memcached
# DynamoDB: uv sync --extra dynamodb
# 全部后端: uv sync --extra alluv run pytest# 基本示例
uv run python examples/basic_usage.py
# FastAPI示例
uv run python examples/fastapi_example.pyMIT License