java 关闭kafka进程_java – Kafka Streams:错误退出的正确方法

我已经成功地获得了一个使用,转换和生成数据的流应用程序,但我注意到,流处理器会定期转换到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的误用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值