我已经成功地获得了一个使用,转换和生成数据的流应用程序,但我注意到,流处理器会定期转换到ERROR状态,并且该进程将在不退出的情况下停留在那里.
显示我的日志:
有没有办法告诉Streams应用程序一旦达到ERROR状态就退出?也许是各种监视器线程?
我看到Kafka Streams代码的注释中的references给需要在应用程序达到此状态时关闭应用程序的用户,但是,我还没有在文档中找到提及此任务的内容.
我的目的是在KafkaStreams对象上设置UncaughtExceptionHandler方法,以执行以下操作:
>记录错误
>使用原始KafkaStreams对象上的close方法关闭流
结果是:
>记录异常消息
> INFO org.apache.kafka.streams.KafkaStreams …从ERROR到PENDING_SHUTDOWN的状态转换
> INFO org.apache.kafka.streams.processor.internals.StreamThread …知情关闭
然后,不幸的是,这个过程似乎没有退出.
FWIW我觉得这可能是对setUncaughtExceptionHandler的误用
最佳答案