io.micronaut.configuration.kafka.streams.KafkaStreamsFactory Maven / Gradle / Ivy
/*
* Copyright 2017-2020 original authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.micronaut.configuration.kafka.streams;
import io.micronaut.configuration.kafka.streams.event.AfterKafkaStreamsStart;
import io.micronaut.configuration.kafka.streams.event.BeforeKafkaStreamStart;
import io.micronaut.context.annotation.Context;
import io.micronaut.context.annotation.EachBean;
import io.micronaut.context.annotation.Factory;
import io.micronaut.context.event.ApplicationEventPublisher;
import org.apache.kafka.streams.KafkaStreams;
import org.apache.kafka.streams.kstream.KStream;
import javax.annotation.PreDestroy;
import javax.inject.Singleton;
import java.io.Closeable;
import java.time.Duration;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
/**
* A factory that constructs the {@link KafkaStreams} bean.
*
* @author Graeme Rocher
* @since 1.0
*/
@Factory
public class KafkaStreamsFactory implements Closeable {
private final Map streams = new ConcurrentHashMap<>();
private final ApplicationEventPublisher eventPublisher;
/**
* Default constructor.
*
* @param eventPublisher The event publisher
*/
public KafkaStreamsFactory(ApplicationEventPublisher eventPublisher) {
this.eventPublisher = eventPublisher;
}
/**
* Exposes the {@link ConfiguredStreamBuilder} as a bean.
*
* @param configuration The configuration
* @return The streams builder
*/
@EachBean(AbstractKafkaStreamsConfiguration.class)
ConfiguredStreamBuilder streamsBuilder(AbstractKafkaStreamsConfiguration, ?> configuration) {
return new ConfiguredStreamBuilder(configuration.getConfig());
}
/**
* Get configured stream and builder for the stream.
*
* @return Map of streams to builders
*/
public Map getStreams() {
return streams;
}
/**
* Builds the default {@link KafkaStreams} bean from the configuration and the supplied {@link ConfiguredStreamBuilder}.
*
* @param builder The builder
* @param kStreams The KStream definitions
* @return The {@link KafkaStreams} bean
*/
@EachBean(ConfiguredStreamBuilder.class)
@Context
KafkaStreams kafkaStreams(
ConfiguredStreamBuilder builder,
KStream, ?>... kStreams
) {
KafkaStreams kafkaStreams = new KafkaStreams(
builder.build(builder.getConfiguration()),
builder.getConfiguration()
);
eventPublisher.publishEvent(new BeforeKafkaStreamStart(kafkaStreams, kStreams));
streams.put(kafkaStreams, builder);
kafkaStreams.start();
eventPublisher.publishEvent(new AfterKafkaStreamsStart(kafkaStreams, kStreams));
return kafkaStreams;
}
/**
* Create the interactive query service bean.
*
* @return Rhe {@link InteractiveQueryService} bean
*/
@Singleton
InteractiveQueryService interactiveQueryService() {
return new InteractiveQueryService(streams.keySet());
}
@Override
@PreDestroy
public void close() {
for (KafkaStreams stream : streams.keySet()) {
try {
stream.close(Duration.ofSeconds(3));
} catch (Exception e) {
// ignore
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy