Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alisaifee/coredis
coredis is an async redis client for python with support for redis cluster & sentinel.
https://github.com/alisaifee/coredis
asyncio python redis redis-client redis-cluster-client redis-sentinel-client
Last synced: about 22 hours ago
JSON representation
coredis is an async redis client for python with support for redis cluster & sentinel.
- Host: GitHub
- URL: https://github.com/alisaifee/coredis
- Owner: alisaifee
- License: mit
- Created: 2021-12-13T17:09:50.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2024-04-29T22:24:23.000Z (9 months ago)
- Last Synced: 2024-05-02T02:12:00.477Z (9 months ago)
- Topics: asyncio, python, redis, redis-client, redis-cluster-client, redis-sentinel-client
- Language: Python
- Homepage: http://coredis.readthedocs.io/en/latest/
- Size: 5.86 MB
- Stars: 65
- Watchers: 6
- Forks: 10
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.rst
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# coredis
[![docs](https://readthedocs.org/projects/coredis/badge/?version=stable)](https://coredis.readthedocs.org)
[![codecov](https://codecov.io/gh/alisaifee/coredis/branch/master/graph/badge.svg)](https://codecov.io/gh/alisaifee/coredis)
[![Latest Version in PyPI](https://img.shields.io/pypi/v/coredis.svg)](https://pypi.python.org/pypi/coredis/)
[![ci](https://github.com/alisaifee/coredis/actions/workflows/main.yml/badge.svg?branch=master)](https://github.com/alisaifee/coredis/actions?query=branch%3Amaster+workflow%3ACI)
[![Supported Python versions](https://img.shields.io/pypi/pyversions/coredis.svg)](https://pypi.python.org/pypi/coredis/)______________________________________________________________________
coredis is an async redis client with support for redis server, cluster & sentinel.
- The client API uses the specifications in the [Redis command documentation](https://redis.io/commands/) to define the API by using the following conventions:
- Arguments retain naming from redis as much as possible
- Only optional variadic arguments are mapped to variadic positional or keyword arguments.
When the variable length arguments are not optional (which is almost always the case) the expected argument
is an iterable of type [Parameters](https://coredis.readthedocs.io/en/latest/api/typing.html#coredis.typing.Parameters) or `Mapping`.
- Pure tokens used as flags are mapped to boolean arguments
- `One of` arguments accepting pure tokens are collapsed and accept a [PureToken](https://coredis.readthedocs.io/en/latest/api/utilities.html#coredis.tokens.PureToken)- Responses are mapped between RESP and python types as closely as possible.
- For higher level concepts such as Pipelines, LUA Scripts, PubSub & Streams
abstractions are provided to encapsulate recommended patterns.
See the [Handbook](https://coredis.readthedocs.io/en/latest/handbook/index.html)
and the [API Documentation](https://coredis.readthedocs.io/en/latest/api/index.html)
for more details.> **Warning**
> The command API does NOT mirror the official python [redis client](https://github.com/redis/redis-py). For details about the high level differences refer to [Divergence from aredis & redis-py](https://coredis.readthedocs.io/en/latest/history.html#divergence-from-aredis-redis-py)______________________________________________________________________
- [Installation](#installation)
- [Feature Summary](#feature-summary)
- [Deployment topologies](#deployment-topologies)
- [Application patterns](#application-patterns)
- [Server side scripting](#server-side-scripting)
- [Redis Modules](#redis-modules)
- [Miscellaneous](#miscellaneous)
- [Quick start](#quick-start)
- [Single Node or Cluster client](#single-node-or-cluster-client)
- [Sentinel](#sentinel)
- [Compatibility](#compatibility)
- [Supported python versions](#supported-python-versions)
- [Redis API compatible databases backends](#redis-api-compatible-databases)
- [References](#references)## Installation
To install coredis:
```bash
$ pip install coredis
```## Feature Summary
### Deployment topologies
- [Redis Cluster](https://coredis.readthedocs.org/en/latest/handbook/cluster.html#redis-cluster)
- [Sentinel](https://coredis.readthedocs.org/en/latest/api/clients.html#sentinel)### Application patterns
- [Connection Pooling](https://coredis.readthedocs.org/en/latest/handbook/connections.html#connection-pools)
- [PubSub](https://coredis.readthedocs.org/en/latest/handbook/pubsub.html)
- [Sharded PubSub](https://coredis.readthedocs.org/en/latest/handbook/pubsub.html#sharded-pub-sub) \[`>= Redis 7.0`\]
- [Stream Consumers](https://coredis.readthedocs.org/en/latest/handbook/streams.html)
- [Pipelining](https://coredis.readthedocs.org/en/latest/handbook/pipelines.html)
- [Client side caching](https://coredis.readthedocs.org/en/latest/handbook/caching.html)### Server side scripting
- [LUA Scripting](https://coredis.readthedocs.org/en/latest/handbook/scripting.html#lua_scripting)
- [Redis Libraries and functions](https://coredis.readthedocs.org/en/latest/handbook/scripting.html#library-functions) \[`>= Redis 7.0`\]### Redis Modules
- [RedisJSON](https://coredis.readthedocs.org/en/latest/handbook/modules.html#redisjson)
- [RediSearch](https://coredis.readthedocs.org/en/latest/handbook/modules.html#redisearch)
- [RedisGraph](https://coredis.readthedocs.org/en/latest/handbook/modules.html#redisgraph)
- [RedisBloom](https://coredis.readthedocs.org/en/latest/handbook/modules.html#redisbloom)
- [RedisTimeSeries](https://coredis.readthedocs.org/en/latest/handbook/modules.html#redistimeseries)### Miscellaneous
- Public API annotated with type annotations
- Optional [Runtime Type Validation](https://coredis.readthedocs.org/en/latest/handbook/typing.html#runtime-type-checking) (via [beartype](https://github.com/beartype/beartype))## Quick start
### Single Node or Cluster client
```python
import asyncio
from coredis import Redis, RedisClusterasync def example():
client = Redis(host='127.0.0.1', port=6379, db=0)
# or with redis cluster
# client = RedisCluster(startup_nodes=[{"host": "127.0.01", "port": 7001}])
await client.flushdb()
await client.set('foo', 1)
assert await client.exists(['foo']) == 1
assert await client.incr('foo') == 2
assert await client.incrby('foo', increment=100) == 102
assert int(await client.get('foo')) == 102assert await client.expire('foo', 1)
await asyncio.sleep(0.1)
assert await client.ttl('foo') == 1
assert await client.pttl('foo') < 1000
await asyncio.sleep(1)
assert not await client.exists(['foo'])asyncio.run(example())
```### Sentinel
```python
import asyncio
from coredis.sentinel import Sentinelasync def example():
sentinel = Sentinel(sentinels=[("localhost", 26379)])
primary = sentinel.primary_for("myservice")
replica = sentinel.replica_for("myservice")assert await primary.set("fubar", 1)
assert int(await replica.get("fubar")) == 1asyncio.run(example())
```To see a full list of supported redis commands refer to the [Command
compatibility](https://coredis.readthedocs.io/en/latest/compatibility.html)
documentationDetails about supported Redis modules and their commands can be found
[here](https://coredis.readthedocs.io/en/latest/handbook/modules.html)## Compatibility
coredis is tested against redis versions `6.2.x`, `7.0.x`, `7.2.x` & `7.4.x`
The test matrix status can be reviewed
[here](https://github.com/alisaifee/coredis/actions/workflows/main.yml)coredis is additionally tested against:
- ` uvloop >= 0.15.0`
### Supported python versions
- 3.9
- 3.10
- 3.11
- 3.12
- 3.13
- PyPy 3.9
- PyPy 3.10### Redis API compatible databases
**coredis** is known to work with the following databases that have redis protocol compatibility:
- [KeyDB](https://docs.keydb.dev/)
- [Dragonfly](https://dragonflydb.io/)
- [Redict](https://redict.io/)
- [Valkey](https://github.com/valkey-io/valkey)## References
- [Documentation (Stable)](http://coredis.readthedocs.org/en/stable)
- [Documentation (Latest)](http://coredis.readthedocs.org/en/latest)
- [Changelog](http://coredis.readthedocs.org/en/stable/release_notes.html)
- [Project History](http://coredis.readthedocs.org/en/stable/history.html)