Ram*_*man 3 apache-kafka apache-kafka-streams
如果我们在后台启动 KafkaStream 应用程序(例如 Linux),是否有办法从外部向应用程序发出信号,以启动正常关闭?
正如文档(https://kafka.apache.org/11/documentation/streams/tutorial)中所述,建议注册一个调用KafkaStreams#close()干净关闭的关闭钩子:
final CountDownLatch latch = new CountDownLatch(1);
// attach shutdown handler to catch control-c
Runtime.getRuntime().addShutdownHook(new Thread("streams-shutdown-hook") {
@Override
public void run() {
streams.close();
latch.countDown();
}
});
try {
streams.start();
latch.await();
} catch (Throwable e) {
System.exit(1);
}
System.exit(0);
Run Code Online (Sandbox Code Playgroud)