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.0.tar.gz (50.0 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: redis_canal-0.1.0.tar.gz
  • Upload date:
  • Size: 50.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.4

File hashes

Hashes for redis_canal-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ba63edd01882580e87a78bf450d2903d85d41954eca4698dbab8ac474d5832ce
MD5 7d971ed03744c59d71acf1a50311f580
BLAKE2b-256 5e6f41e122529f47d4a462d1368cb02716d6f7b2dabae839aca136bd94b3fd9b

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for redis_canal-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 048ad50f7a6e4d5fc98d9b1f86adc56a5236cfe4b3eaf12348fcf3d577c7ee7a
MD5 92f0131abaf3d99edbc15a46cc75e069
BLAKE2b-256 2f7043cb065fabfcc28c966e2d4c8f20f59cbd08eafed4a39fe8118dc6454c2c

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