Kafka制作人在运行时抛出eofexception

yduiuuwa  于 2021-06-08  发布在  Kafka
关注(0)|答案(2)|浏览(369)

我正在使用kafka0.8.2.1和新的producerapi。服务器设置为本地网络中的单个节点。
问题是制片人抛出了一个 EOFException 在运行了一段时间后(上次我检查了15分钟),但这似乎并不重要,因为我的制作人在这之后继续工作。
我初始化生产者的方式:

Map<String, Object> configs = new HashMap<>();
configs.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "192.168.1.101:9092");
configs.put(ProducerConfig.ACKS_CONFIG, "1");
configs.put(ProducerConfig.BLOCK_ON_BUFFER_FULL_CONFIG, "false");
configs.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
configs.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
this.producer = new KafkaProducer<>(configs);

我得到的例外是:

WARN  [2015-06-17 02:07:28,896] org.apache.kafka.common.network.Selector: Error in I/O with /192.168.1.101
! java.io.EOFException: null
! at org.apache.kafka.common.network.NetworkReceive.readFrom(NetworkReceive.java:62) ~[kafka-clients-0.8.2.1.jar:na]
! at org.apache.kafka.common.network.Selector.poll(Selector.java:248) ~[kafka-clients-0.8.2.1.jar:na]
! at org.apache.kafka.clients.NetworkClient.poll(NetworkClient.java:192) [kafka-clients-0.8.2.1.jar:na]
! at org.apache.kafka.clients.producer.internals.Sender.run(Sender.java:191) [kafka-clients-0.8.2.1.jar:na]
! at org.apache.kafka.clients.producer.internals.Sender.run(Sender.java:122) [kafka-clients-0.8.2.1.jar:na]
! at java.lang.Thread.run(Thread.java:745) [na:1.8.0_45]

即使我的代码仍然可以处理这个问题,我想知道为什么以及如何防止它。

mbzjlibv

mbzjlibv1#

https://issues.apache.org/jira/browse/kafka-3205 建议增加connections.max.idle.ms

vwkv1x7d

vwkv1x7d2#

您是否尝试更改“connections.max.idle.ms”?默认值为15分钟。如果每15分钟出现一次此错误,请尝试减少此超时。

相关问题