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

io.confluent.parallelconsumer.examples.vertx.VertxApp Maven / Gradle / Ivy

There is a newer version: 0.5.3.2
Show newest version
package io.confluent.parallelconsumer.examples.vertx;

/*-
 * Copyright (C) 2020 Confluent, Inc.
 */

import io.confluent.parallelconsumer.ParallelConsumerOptions;
import io.confluent.parallelconsumer.vertx.JStreamVertxParallelStreamProcessor;
import io.confluent.parallelconsumer.vertx.VertxParallelEoSStreamProcessor.RequestInfo;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.RandomUtils;
import org.apache.kafka.clients.consumer.Consumer;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.Producer;
import pl.tlinkowski.unij.api.UniLists;
import pl.tlinkowski.unij.api.UniMaps;

import java.time.Duration;
import java.util.Map;
import java.util.Properties;

@Slf4j
public class VertxApp {

    static String inputTopic = "input-topic-" + RandomUtils.nextInt();

    Consumer getKafkaConsumer() {
        return new KafkaConsumer<>(new Properties());
    }

    Producer getKafkaProducer() {
        return new KafkaProducer<>(new Properties());
    }

    JStreamVertxParallelStreamProcessor parallelConsumer;


    void run() {
        Consumer kafkaConsumer = getKafkaConsumer();
        Producer kafkaProducer = getKafkaProducer();
        var options = ParallelConsumerOptions.builder()
                .ordering(ParallelConsumerOptions.ProcessingOrder.KEY)
                .maxMessagesToQueue(1000)
                .maxNumberMessagesBeyondBaseCommitOffset(10000)
                .consumer(kafkaConsumer)
                .producer(kafkaProducer)
                .build();

        setupSubscription(kafkaConsumer);

        this.parallelConsumer = JStreamVertxParallelStreamProcessor.createEosStreamProcessor(options);

        int port = getPort();

        // tag::example[]
        var resultStream = parallelConsumer.vertxHttpReqInfoStream(record -> {
            log.info("Concurrently constructing and returning RequestInfo from record: {}", record);
            Map params = UniMaps.of("recordKey", record.key(), "payload", record.value());
            return new RequestInfo("localhost", port, "/api", params); // <1>
        });
        // end::example[]

        resultStream.forEach(x -> {
            log.info("From result stream: {}", x);
        });

    }

    protected int getPort() {
        return 8080;
    }

    void setupSubscription(Consumer kafkaConsumer) {
        kafkaConsumer.subscribe(UniLists.of(inputTopic));
    }

    void close() {
        this.parallelConsumer.closeDrainFirst(Duration.ofSeconds(2));
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy