All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.example.interceptor.zipkin.ConsumerApp Maven / Gradle / Ivy

package com.example.interceptor.zipkin;

import java.time.Duration;
import java.util.Arrays;
import java.util.Collections;
import java.util.Properties;
import no.sysco.middleware.kafka.interceptor.zipkin.TracingConsumerInterceptor;
import no.sysco.middleware.kafka.interceptor.config.ConfigHarvesterInterceptor;
import org.apache.kafka.clients.consumer.Consumer;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.serialization.StringDeserializer;

public class ConsumerApp {
  public static void main(String[] args) {
    Properties consumerConfig = new Properties();
    consumerConfig.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:29092");
    consumerConfig.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
    consumerConfig.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
    consumerConfig.put(ConsumerConfig.GROUP_ID_CONFIG, "consumer-group-1");
    consumerConfig.put(ConsumerConfig.INTERCEPTOR_CLASSES_CONFIG,
        Arrays.asList(TracingConsumerInterceptor.class, ConfigHarvesterInterceptor.class));

    Consumer consumer = new KafkaConsumer<>(consumerConfig);
    consumer.subscribe(Collections.singletonList("test"));

    ConsumerRecords consumerRecords = consumer.poll(Duration.ofSeconds(10));

    for (ConsumerRecord record : consumerRecords) {
      System.out.println(record);
    }

    consumer.commitSync();

    try {
      Thread.sleep(3000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy