Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/evanshortiss/neon-debezium-redis-cdc
Learn how to implement Change Data Capture and Fan-out with Neon's serverless Postgres, Debezium, and Upstash Redis
https://github.com/evanshortiss/neon-debezium-redis-cdc
debezium neondb postgres postgresql redis redis-stream redis-streams serverless
Last synced: 22 days ago
JSON representation
Learn how to implement Change Data Capture and Fan-out with Neon's serverless Postgres, Debezium, and Upstash Redis
- Host: GitHub
- URL: https://github.com/evanshortiss/neon-debezium-redis-cdc
- Owner: evanshortiss
- Created: 2024-02-10T01:43:40.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-02-10T01:56:05.000Z (11 months ago)
- Last Synced: 2024-10-24T08:12:07.889Z (2 months ago)
- Topics: debezium, neondb, postgres, postgresql, redis, redis-stream, redis-streams, serverless
- Language: TypeScript
- Homepage:
- Size: 745 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Change Data Capture with Neon serverless Postgres, Debezium, and Redis
This repository is a companion to a blogpost on the Neon Blog. It provides a
template for getting started with [Neon](https://neon.tech) and
[Debezium](https://debezium.io) to perform Change Data Capture.Using Change Data Capture enables you to stream database changes to messaging
infrastructure such as Kafka, Redis, and Pub/Sub systems without suffering
from data inconsistency caused by [dual writes](https://thorben-janssen.com/dual-writes/). Downstream systems can consume these messages to enable Event-Driven Architectures.![Architecture that shows Debezium consuming changes from a Neon Postgres database and streaming the changes to Redis](/images/architecture.png)
## Getting Started
1. Obtain a Neon Postgres database.
2. Obtain a Redis instance from Upstash.
3. Define environment variables.
4. Start Debezium Server.
5. Confirm that changes are streamed to Redis.### Configure Neon Postgres
1. Sign up to [console.neon.tech](https://console.neon.tech/) and create a project to obtain a serverless Postgres database.
1. [Enable Logical Replication](https://neon.tech/docs/guides/logical-replication-concepts#enabling-logical-replication) for your Neon project.
1. Create a table and insert data using Neon's SQL Editor:
```sql
CREATE TABLE playing_with_neon(id SERIAL PRIMARY KEY, name TEXT NOT NULL, value REAL);INSERT INTO playing_with_neon (name, value)
VALUES
('Mario', random()),
('Peach', random()),
('Bowser', random()),
('Luigi', random()),
('Yoshi', random());
```### Configure Upstash Redis
1. Sign up and create a Redis database on [console.upstash.com](https://console.upstash.com/) with the following settings:
* Name: neon-debezium
* Type: Regional
* Region: Select the region closest to your Neon Postgres database.
* TLS (SSL) Enabled: Yes
* Eviction: Yes### Set Environment Variables
1. Copy the `.env.example` to a file named `.env`
1. Replace the Postgres connection parameters in `.env` with your own values from Neon
1. Replace the Redis connection parameters with your own values from Upstash.### Start Debezium
Start a Debezium Server container, passing the `.env` file and
`application.properties` to it:```bash
docker run --net neon-debezium-redis \
--rm \
--name debezium-server \
--env-file=.env \
-v $PWD/debezium:/debezium/conf \
debezium/server:2.5.1.Final
```A few moments after Debezium starts, you should see that it prints logs that
confirms it has performed an initial snapshot of the `playing_with_neon` table,
and is now listening for WAL changes.### Confirm Changes are Streamed to Redis
Visit the Data Browser for your Redis instance in Upstash and you should see
that a `debezium.public.playing_with_neon` [Redis stream](https://redis.io/docs/data-types/streams/)
has been created, and contains records corresponding to `INSERT` events from
your `playing_with_neon` table.Perofrming more `INSERT` or `UPDATE` operations will result in new messages appearing in
the Redis stream.![](/images/upstash-data-browser.png)
## Consuming the Change Stream
A sample application is included in the *stream-consumer/* folder. It uses the
Redis Node.js client to consume the stream of database changes in the
`debezium.public.playing_with_neon` Redis key, and create a sum of "scores" for
each player in Redis.For example, performing the following two `INSERT` operations would result in a
`sum:mario` key being created in Redis with a value of `2.1`:```sql
INSERT INTO playing_with_neon (name, value) VALUES ('Mario', '1.5')
INSERT INTO playing_with_neon (name, value) VALUES ('Mario', '0.6')
```To run the Node.js application:
1. Create a copy of the `.env.example` named `.env` in thw *stream-consumer/* folder.
1. Replace the sample values with your Upstash Redis connection parameters. Note that `rediss://` is the correct protocol to use if SSL is enabled for your Upstash Redis instance.
1. Run `npm install` to install dependencies.
1. Run `npm run` to start the application.Once the application starts it will continuously update Redis keys as `INSERT`
events are written to the stream key by Debezium.