Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cr0hn/aioredis-watchdog
Redis watchdog for key changes
https://github.com/cr0hn/aioredis-watchdog
asyncio pipeline python redis shell unix watchdog
Last synced: 19 days ago
JSON representation
Redis watchdog for key changes
- Host: GitHub
- URL: https://github.com/cr0hn/aioredis-watchdog
- Owner: cr0hn
- Created: 2020-04-29T12:58:43.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-05-27T08:42:22.000Z (over 4 years ago)
- Last Synced: 2024-12-12T09:37:55.113Z (about 1 month ago)
- Topics: asyncio, pipeline, python, redis, shell, unix, watchdog
- Language: Python
- Homepage:
- Size: 19.5 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
Redis Watchdog
==============This project allow to monitor Redis keys for changes and launch callbacks.
Support this project
====================Support this project (to solve issues, new features...) by applying the Github "Sponsor" button.
Install
=======.. code-block:: console
$ pip install aioredis-watchdog
Concepts
========Redis pattern
-------------You can configure which Redis keys you wish to watch by using a *redis pattern*.
Callbacks
---------Each time a key was changed in Redis, `aioredis-watchdog` will call the list of callbacks.
Using as library
================For monitoring all Redis keys that starts by *user-*:
.. code-block:: python
import asyncio
from aioredis_watchdog import watchdog
async def callback1(key: str, data: bytes):
print("Key callback 1: ", key, "#", data)async def callback2(key: str, data: bytes):
print("Key callback 2: ", key, "#", data)async def monitoring(connection_string: str):
redis = await aioredis.create_redis_pool(connection_string)callbacks = [callback1, callback2]
await watchdog("user-*", callbacks, redis)
asyncio.run(monitoring("redis://localhost"))
Callbacks must have this signature:
.. code-block:: python
async def FUNCTION_NAME(KEY: str, VALUE: bytes):
...Where:
- Function is a coroutine
- KEY: is the key name in redis and is plain string
- VALUE: is the value for this key in Redis. It's in bytes format.You also can config the maximum number of processing packages for `watchdog`.
In this example only 10 changes will be processed:
.. code-block:: python
...
await watchdog("user-*", callbacks, redis, count=10)
...
Using as CLI
============You also can use the library as cli. When you install the package a new command will be available: `redis-watchdog`:
.. code-block:: console
$ redis-watchdog -h
Usage in a pipeline
-------------------You can use redis-watchdog in a *NIX pipeline. You only must set the parameter `-P` to activate it.
At the next step in the pipeline the string "KEY VALUE" will be received. Let me illustrate using an example:
.. code-block:: console
$ redis-watcher -q -P -c 10 | awk '{print $1" ### "$2}'
x6777 ### 80c853a94a0d41ac886ad77ab6441484
x6778 ### afd97f42cbad45a08468e03b3189f753
x6779 ### 26a62f14e9224ed2a429f946a0712f57
x6780 ### b1da88cf24354f77a8ebefc960db1dcc
x6781 ### 2aac5c5f60884025b307f1639ac0392f
x6782 ### 0657604ac8b247e099a6ff1ea7087dc6
x6783 ### f582353a5b3544109fec1a49624fe6bd
x6784 ### 09deb8da158a4ab5bd45d889fb3907b0
x6785 ### 82c8e99b83cf47b0928cabce67a24c54
x6786 ### 541a36e4efee4a65a4c84c95af23ecee
x6787 ### 77c89aaec0e94e588726ab3dbf71a6d4Oks, let explain the rest of the flags:
- `-q` to enable quiet mode.
- `-P` to enable pipeline mode
- `-c` to limit events to process to 10.To generate data the script `data_producer.py` at the `examples/` folder was used.
Another example:
Call an end-point by each key:
.. code-block:: console
$ redis-watcher -q -P -c 10 | awk '{print "http://mysite.com/callback?key="$1"&value="$2}' | xargs -n1 wget -O - -q