【发布时间】:2018-05-14 01:24:36
【问题描述】:
如果我们在后台启动 KafkaStream 应用程序(比如 Linux),是否有办法从外部向应用程序发出信号,从而启动正常关闭?
【问题讨论】:
标签: apache-kafka apache-kafka-streams
如果我们在后台启动 KafkaStream 应用程序(比如 Linux),是否有办法从外部向应用程序发出信号,从而启动正常关闭?
【问题讨论】:
标签: apache-kafka apache-kafka-streams
如文档 (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);
【讨论】:
Ctrl-C 发送SIGINT 信号,而普通kill <pid> 发送SIGTERM。这些信号被关闭钩子覆盖(参见docs.oracle.com/javase/8/docs/api/java/lang/Runtime.html 和stackoverflow.com/a/2541618/1743580)。未涵盖的是来自kill -9 <pid> 的SIGKILL。我建议阅读 Java 文档——这并不特定于 Kafka 的 Streams API。
StreamThreads。