KV backed dictionary, similar to RedisJSONDict
Project description
kv-dict
KV backed dictionary, similar to RedisJSONDict
Install Package
- pip:
pip install kv-dict - uv:
uv add kv-dict- add
--optional FEATUREto add as an optional dependency
- add
- pixi:
pixi add --pypi kv-dict- add
--feature FEATUREto add as an optional dependency
- add
Development
This project uses uv for managing project dependencies. Installation
instructions may be found
here.
git clone https://github.com/Canadian-Light-Source/kv-dict.git
cd kv-dict
uv sync --all-extras
Remote Mapping + In-Memory Backend Example
Run a basic RemoteKVMapping flow backed by InMemoryAsyncBackend:
uv run python examples/remote_mapping_in_memory_example.py
Remote Mapping + Redis/Dragonfly Backend Example
Run a basic RemoteKVMapping flow backed by a Redis-compatible server:
uv run python examples/remote_mapping_redis_example.py
[!NOTE] In the devcontainer compose setup, the Redis-compatible service hostname is
redis.
Remote Mapping + PostgreSQL Backend Example
Run a basic RemoteKVMapping flow backed by PostgreSQL:
uv run python examples/remote_mapping_postgres_example.py
[!NOTE] In the devcontainer compose setup, PostgreSQL is available on the internal hostname/port
postgres:5432.
Remote Mapping + NATS JetStream KV Backend Example
Run a basic RemoteKVMapping flow backed by NATS JetStream KV:
uv run python examples/remote_mapping_nats_example.py
[!IMPORTANT] This example uses
create_bucket=False(production-style). Ensure thekv_dictbucket already exists.
[!NOTE] In the devcontainer compose setup, NATS is also available to host-side tools at
nats://127.0.0.1:14222.
Watch the changes in the NATS KV with the CLI client:
nats -s localhost:14222 kv watch kv_dict
Create the kv_dict bucket locally (for testing)
Run this once before executing the NATS example:
uv run python - <<'PY'
import asyncio
import nats
async def main() -> None:
nc = await nats.connect(servers=["nats://nats:4222"])
try:
js = nc.jetstream()
try:
await js.key_value("kv_dict")
print("Bucket already exists: kv_dict")
except Exception:
await js.create_key_value(bucket="kv_dict")
print("Created bucket: kv_dict")
finally:
await nc.close()
asyncio.run(main())
PY
Differences from Python dict
RemoteKVMapping is intentionally dict-like, but not a byte-for-byte
replacement of the built-in dict behavior.
Key behavioral differences
- Iteration order is sorted by key, not insertion order.
- Values are persisted through backend round-trips, so operations are not purely in-memory.
- Nested
dictandlistmutations are write-through. - Mutable non-dict/non-list values are not automatically write-through.
Missing / non-parity APIs
fromkeys()is not implemented.
Practical guidance
[!WARNING]
RemoteKVMappingis backend-backed, not purely in-memory. Avoid relying on insertion-order behavior and reassignment-free updates for mutable non-list, non-dict nested values.
- Treat this mapping as a backend-backed structure, not an in-memory object.
- For nested non-dict updates, reassign the modified value to persist changes.
- If strict insertion-order semantics are required, do not rely on iteration
order from
RemoteKVMapping.
Dict parity roadmap
- Implement
copy()semantics for backend-backed snapshots. - Implement in-place dict union operator (
|=). - Implement dict union operator (
|). - Implement
fromkeys()with explicit persistence semantics. - Add write-through wrappers for list operations.
- Add write-through wrappers for additional mutable container types (if required).
- Decide and document stable ordering strategy (sorted vs insertion-order).
- Add dedicated parity tests against a reference
dictbehavior matrix.
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 kv_dict-0.1.7.tar.gz.
File metadata
- Download URL: kv_dict-0.1.7.tar.gz
- Upload date:
- Size: 120.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d90b3d03661d14ab5d914e2779a92bde15cbb15fe0cf869b2964bd20311eb605
|
|
| MD5 |
4706ae13b1dcf2f66afcf74295c0d703
|
|
| BLAKE2b-256 |
691832e9e31c37539bf19783a7eeebb46db6565da7b3ef0985fcef44ca6b3983
|
File details
Details for the file kv_dict-0.1.7-py3-none-any.whl.
File metadata
- Download URL: kv_dict-0.1.7-py3-none-any.whl
- Upload date:
- Size: 27.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
48537fb3b350fb48ed2f6f34187d4bcc3b09a7e09e1ed2d707a094b0828f261b
|
|
| MD5 |
b78b366f89f4040e2d4602a278a97229
|
|
| BLAKE2b-256 |
025ee9d7df2661c94d8be0054406b075209a9fd9250cbcf4fd93d2b3de0cf6a7
|