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:
- Log the received records.
- Map the values of the records and throw a processing exception if the birthdate is negative.
- Process the values of the records and throw a processing exception if the last name or the first name is empty.
- Schedule a punctuation every 1 minute to throw a processing exception.
- 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.
To compile and run this demo, you will need the following:
- Java 21
- Maven
- Docker
To run the application manually:
- Start a Confluent Platform in a Docker environment.
- Produce records of type
<String, KafkaUser>
to a topic namedUSER_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