Skip to content

Latest commit

 

History

History

kafka-streams-exception-handler-processing

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

Kafka Streams Processing Exception Handler

This module demonstrates the following:

  • The use of the Kafka Streams configuration processing.exception.handler to handle processing exceptions that occur in DSL operations and the processor API.
  • The implementation of a custom processing exception handler.
  • Unit testing using Topology Test Driver.

In this module, records of type <String, KafkaUser> are streamed from a topic named USER_TOPIC. The following tasks are performed:

  1. Log the received records.
  2. Map the values of the records and throw a processing exception if the birthdate is negative.
  3. Process the values of the records and throw a processing exception if the last name or the first name is empty.
  4. Schedule a punctuation every 1 minute to throw a processing exception.
  5. Write the records as they are to a new topic named USER_PROCESSING_EXCEPTION_HANDLER_TOPIC.

The custom processing exception handler is invoked when any of these exceptions are thrown. It logs the exceptions and continues processing for IllegalArgumentException, but fails the processing for other exceptions.

topology.png

Prerequisites

To compile and run this demo, you will need the following:

  • Java 21
  • Maven
  • Docker

Running the Application

To run the application manually:

  • Start a Confluent Platform in a Docker environment.
  • Produce records of type <String, KafkaUser> to a topic named USER_TOPIC. You can use the producer user to do this.
  • Start the Kafka Streams application.

To run the application in Docker, use the following command:

docker-compose up -d

This command will start the following services in Docker:

  • 1 Kafka broker (KRaft mode)
  • 1 Schema registry
  • 1 Control Center
  • 1 producer User
  • 1 Kafka Streams Exception Handler Processing