一尘不染

Spring-Cloud-Stream Kafka Azure-提取数据时出现意外错误代码13

spring-boot

我正在开发dockerized的SpringBoot应用程序。docker映像是微服务,其中之一与Azure Event Hub通信。

我的一些属性:

Spring引导-> 2.0.7.RELEASE

spring-cloud.version-> Finchley.SR2

我已经在Azure中创建了一个主题( 启用Kafka )。

我遵循了一些简单的指南来设置我的微服务,并且一切正常。

@EnableBinding({Processor.class})
public class EventService {
    ...
    @Autowired private Processor ehProcessor;
    ...
    public void send(String event) {

        Message<String> message = MessageBuilder
                .withPayload(event)
                .setHeader(MessageHeaders.CONTENT_TYPE, MimeTypeUtils.APPLICATION_JSON)
                .build();

        boolean send = ehProcessor.output().send(message, 5000L);

        if (!send) {

            log.error("Event NOT sent", event);
        }
    }

    ...

    @StreamListener(target = Processor.INPUT)
    public void receive(String event) {

        handle(event);
    }
}

一整个月的时间一切都很好,但是在最近的两天中,微服务卡住了,因为连续的堆栈跟踪填充了我的所有磁盘(解决方案是设置docker日志轮换)。

java.lang.IllegalStateException: Unexpected error code 13 while fetching data
        at org.apache.kafka.clients.consumer.internals.Fetcher.parseCompletedFetch(Fetcher.java:891) ~[kafka-clients-1.0.1.jar!/:na]
        at org.apache.kafka.clients.consumer.internals.Fetcher.fetchedRecords(Fetcher.java:528) ~[kafka-clients-1.0.1.jar!/:na]
        at org.apache.kafka.clients.consumer.KafkaConsumer.pollOnce(KafkaConsumer.java:1154) ~[kafka-clients-1.0.1.jar!/:na]
        at org.apache.kafka.clients.consumer.KafkaConsumer.poll(KafkaConsumer.java:1111) ~[kafka-clients-1.0.1.jar!/:na]
        at org.springframework.kafka.listener.KafkaMessageListenerContainer$ListenerConsumer.run(KafkaMessageListenerContainer.java:699) ~[spring-kafka-2.1.7.RELEASE.jar!/:2.1.7.RELEASE]
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [na:1.8.0_181]
        at java.util.concurrent.FutureTask.run(FutureTask.java:266) [na:1.8.0_181]
        at java.lang.Thread.run(Thread.java:748) [na:1.8.0_181]

我说的是1毫秒内的8/9日志消息。

org.apache.kafka.common.protocol.Errors 类内部查看,该错误与以下内容有关:

NETWORK_EXCEPTION(13,“服务器在收到响应之前已断开连接。”

我无法以编程方式重现此错误。我不明白为什么在出现第一个错误时日志将开始并且在无限循环中不停止。我需要停止docker容器,有时容器不会停止。唯一的解决方案是删除容器,然后重新创建。

更新

我已经打开GitHub上的问题在这里。我已经收到了回复,他们开始对此进行调查。

更新

该问题已解决。

当他们将UnknownServerException更改为NetworkException时,Spring Boot开始陷入重试循环。


阅读 318

收藏
2020-05-30

共1个答案

一尘不染

它已在此链接中确认,

最近发生了更改,将UnknownServerException的实例更改为NetworkException。

问题详细信息在这里-https://github.com/Azure/azure-event-hubs-for-
kafka/issues-以及您的命名空间信息。谢谢!

2020-05-30