Debezium Management Platform (Debezium Orchestra) aims to provide means to simplify the deployment of Debezium to various environments in highly opinionated manner. The goal is not to provide total control over environment specific configuration. To achieve this goal the platform uses a data-centric view on Debezium components.
Disclaimer: This project is still in early development stage and should not be used in production.
The platform is composed of two main components:
- Conductor: The back-end component which provides a set of APIs to orchestrate and control Debezium deployments.
- Stage: The front-end component which provides a user interface to interact with the Conductor.
The conductor component itself is composed of several subcomponents:
- API Server: The main entry point for the platform. It provides a set of APIs to interact with the platform.
- Watcher: Component responsible for the actual communication with deployment environment (e.g. Debezium Operator in K8s cluster).
You can install the platform through helm chart. For instructions refer to the README
If you don't have already a Kubernetes cluster up, you can use one of the commons tools to have a local K8s cluster
The prerequisite is to install an ingress controller.
For this example, considering a local setup, we will use the /etc/hosts
to resolve the domain.
The following script will map the K8s IP to the specified domain into the /etc/hosts
.
export DEBEZIUM_PLATFORM_DOMAIN=platform.debezium.io
./examples/update_hosts.sh
NOTE: If you are using minikube on Mac, you need also to run the
minikube tunnel
command. For more details see this and this.
Create a dedicated namespace
kubectl create ns debezium-platform
and then install debezium-platform through helm
cd helm &&
helm dependency build &&
helm install debezium-platform . -f ../examples/example.yaml &&
cd ..
after all pods are running you should access the platform UI from http://platform.debezium.io/
To finish the example we will create a PostgreSQL, that will be used as source database, and a kafka cluster, used as destination in our example pipeline.
# Deploy the source database
kubectl create -f examples/k8s/database/001_postgresql.yml
Install the Strimzi operator
helm repo add strimzi https://strimzi.io/charts/ &&
helm repo update strimzi &&
helm install strimzi-operator strimzi/strimzi-kafka-operator --version 0.44.0 --namespace debezium-platform
# Deploy the kafka cluster
kubectl create -f examples/k8s/kafka/001_kafka.yml
# Create a test pipeline
./examples/seed.sh platform.debezium.io 80 examples/payloads/
And that's all.
You should have a test pipeline configured to move data from PostgreSQL to Kakfa.