Skip to main content

redis_canal

Project description

codecov

redis-canal

Proxy redis stream from one to another through global queue service.

Motivation: Redis provided on the cloud is usually only available within a VPC and does not provide external access. We want to provide a way to synchronize messages across clouds without going through a VPN.

Architecture Overview

Supported queue service

  • AWS SQS

Welcome to contribute more queue service, see adapter/impl for more details.

We also support the plugin system, the adapter can also be imported as a third-party library. See example for more details.

Install

pip install redis-canal[all] for all components.

Or use docker image

docker pull wh1isper/redis-canal

Usage

Use CLI

  • redis-canal stream-to-queue to start a daemon to consume redis stream and push to global queue
  • redis-canal queue-to-stream to pull from global queue and push to redis stream

CLI args support envvar, which you can refer to envs.py.

TODO

  • More adapter for Google PubSub, Kafka, etc
  • Allows users to more easily configure the adapter(Now only support environment variables, within Adapter)

Develop

Install pre-commit before commit

pip install pre-commit
pre-commit install

Install package locally

pip install -e .[test]

Run unit-test before PR

pytest -v tests

Develop sqs adapter

You need to configure your AWS account first. See AWS CLI docs for more details.

Make sure your account has sqs:* permission. Then you can run pytest -v tests/adapter/test_sqs_adapter.py to test it.

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

redis_canal-0.1.5.tar.gz (50.2 kB view details)

Uploaded Source

Built Distribution

redis_canal-0.1.5-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

File details

Details for the file redis_canal-0.1.5.tar.gz.

File metadata

  • Download URL: redis_canal-0.1.5.tar.gz
  • Upload date:
  • Size: 50.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for redis_canal-0.1.5.tar.gz
Algorithm Hash digest
SHA256 a070884a93217db33a9977a960890f5787a8dae1a7e715fab10d7c435bce3a5d
MD5 cbde15ab0866021aaa5b8f88358d8b92
BLAKE2b-256 cf81458ec889693bc756cc51b8f056423797267c33955cd25b081897005abbc0

See more details on using hashes here.

File details

Details for the file redis_canal-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: redis_canal-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 14.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for redis_canal-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 bfecbabe2c1f7ad5c33b26a7fa78d6cb88d92bd8440fccb92de8289712185950
MD5 80e1f50a58370c272feadc1a5b76f9b5
BLAKE2b-256 7745dba6a6347c56a6dcce1872226b39785bda4ff449a7cb35b9d94f3a19f971

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page