Simple cache with pydantic.
Project description
cachetic
A simple, type-safe caching library supporting Redis and disk storage with automatic Pydantic serialization.
Features
- Type-safe: Full type checking with generic support
- Flexible backends: Local disk cache (diskcache), Redis, or MongoDB
- Pydantic integration: Automatic serialization for any type via TypeAdapter
- Compression support: Optional zstd/zlib compression with automatic detection
- Connection pooling: Shared MongoClient instances and deduplicated index creation (v0.6.0)
- Simple API: Just
get()andset()with optional TTL
Installation
pip install cachetic
Quick Start
Basic Usage
import pydantic
from cachetic import Cachetic
# Define your model
class Person(pydantic.BaseModel):
name: str
age: int
# Create cache instance
cache = Cachetic[Person](
object_type=pydantic.TypeAdapter(Person),
cache_url=".cache" # Local disk cache
)
# Store and retrieve
person = Person(name="Alice", age=30)
cache.set("user:1", person)
result = cache.get("user:1")
print(result.name) # "Alice"
Redis Backend
cache = Cachetic[Person](
object_type=pydantic.TypeAdapter(Person),
cache_url="redis://localhost:6379/0"
)
MongoDB Backend
pip install cachetic[mongodb]
cache = Cachetic[Person](
object_type=pydantic.TypeAdapter(Person),
cache_url="mongodb://localhost:27017/mydb?collection=mycache"
)
Multiple Cachetic instances sharing the same MongoDB connection string automatically
reuse a single MongoClient, avoiding repeated authentication handshakes and redundant
index creation.
Primitive Types
# String cache
str_cache = Cachetic[str](
object_type=pydantic.TypeAdapter(str),
cache_url=".cache"
)
str_cache.set("greeting", "Hello, World!")
print(str_cache.get("greeting")) # "Hello, World!"
# List cache
list_cache = Cachetic[list[str]](
object_type=pydantic.TypeAdapter(list[str]),
cache_url=".cache"
)
list_cache.set("items", ["apple", "banana", "cherry"])
Complex Types
from typing import Dict, List
# Dictionary cache
data = {"users": [{"id": 1, "name": "Alice"}], "total": 1}
dict_cache = Cachetic[Dict](
object_type=pydantic.TypeAdapter(Dict),
cache_url=".cache"
)
dict_cache.set("user_data", data)
# List of models
people_cache = Cachetic[List[Person]](
object_type=pydantic.TypeAdapter(List[Person]),
cache_url=".cache"
)
people = [Person(name="Alice", age=30), Person(name="Bob", age=25)]
people_cache.set("team", people)
Compression Support
Enable compression to reduce storage space and bandwidth usage:
# Enable compression (auto-selects best algorithm)
cache = Cachetic[Person](
object_type=pydantic.TypeAdapter(Person),
cache_url=".cache",
compression=True # New in v0.5.0
)
person = Person(name="Alice", age=30)
cache.set("user:1", person) # Automatically compressed
result = cache.get("user:1") # Automatically decompressed
Compression Algorithms:
- zstd (preferred): Used if
zstandardpackage is installed - zlib (fallback): Built-in Python standard library
Automatic Detection:
- Caches with
compression=Falsecan still read compressed data - Automatic decompression occurs when compressed data is detected
- Seamless migration between compressed and uncompressed caches
Installation with zstd support:
pip install cachetic zstandard
Configuration
Constructor Parameters
object_type:pydantic.TypeAdapter[T]- Required type adapter for serializationcache_url: Cache backend - file path for disk cache,redis://...for Redis, ormongodb://...for MongoDBdefault_ttl: Default expiration in seconds (-1= no expiration,0= disabled)prefix: Key prefix for all cache operationscompression: Enable compression for cached values (default:False)
TTL Examples
# No expiration (default)
cache = Cachetic[str](
object_type=pydantic.TypeAdapter(str),
default_ttl=-1
)
# 1 hour expiration
cache = Cachetic[str](
object_type=pydantic.TypeAdapter(str),
default_ttl=3600
)
# Per-operation TTL
cache.set("key", "value", ex=300) # 5 minutes
Environment Variables
Use CACHETIC_ prefix:
export CACHETIC_CACHE_URL="redis://localhost:6379/0"
export CACHETIC_DEFAULT_TTL=3600
export CACHETIC_PREFIX="myapp"
export CACHETIC_COMPRESSION=true
Error Handling
from cachetic import CacheNotFoundError
# get() returns None for missing keys
result = cache.get("nonexistent") # None
# get_or_raise() throws exception
try:
result = cache.get_or_raise("nonexistent")
except CacheNotFoundError:
print("Key not found")
License
MIT License
Project details
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 cachetic-0.6.0.tar.gz.
File metadata
- Download URL: cachetic-0.6.0.tar.gz
- Upload date:
- Size: 10.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.2 CPython/3.11.11 Darwin/25.3.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
508932c802d6abbc1e05894a65931753bee0bb004055794ea98813a29e52dc2e
|
|
| MD5 |
f2b1c2410f338c71e3d634e4d0685e33
|
|
| BLAKE2b-256 |
6b86b3d0222cb027678eb1c3b6f3e9ab7676784dcc6c7c4161998d780f9d5e3c
|
File details
Details for the file cachetic-0.6.0-py3-none-any.whl.
File metadata
- Download URL: cachetic-0.6.0-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.3.2 CPython/3.11.11 Darwin/25.3.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0f1ed49a2f5dee7372ea4684e6532375448e2d6825c56cf0b22ddb16684f591
|
|
| MD5 |
8c1e6de915ea7a448196dbe4d3b68946
|
|
| BLAKE2b-256 |
7c1482c7e2442a5992ab4c1098959408982fd9c9816e6d341cdb1a4a5b548f26
|