首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >卡夫卡生产者抛出'TimeoutException:批处理过期‘异常

卡夫卡生产者抛出'TimeoutException:批处理过期‘异常
EN

Stack Overflow用户
提问于 2017-01-12 09:49:50
回答 1查看 3.3K关注 0票数 2

我正在为twitter测试应用程序,用以下与Kafka相关的环境属性启动了docker容器,

代码语言:javascript
复制
KAFKA_ADVERTISED_HOST_NAME=<ip>
advertised.host.name=<ip>:9092
spring.cloud.stream.bindings.output.destination=twitter-source-test
spring.cloud.stream.kafka.binder.brokers=<ip>:9092
spring.cloud.stream.kafka.binder.zkNodes=<ip>:2181

我的卡夫卡producerConfig值如下,

代码语言:javascript
复制
 2017-01-12 14:47:09.979  INFO 1 --- [itterSource-1-1] o.a.k.clients.producer.ProducerConfig    : ProducerConfig values: 
compression.type = none
metric.reporters = []
metadata.max.age.ms = 300000
metadata.fetch.timeout.ms = 60000
reconnect.backoff.ms = 50
sasl.kerberos.ticket.renew.window.factor = 0.8
bootstrap.servers = [192.168.127.188:9092]
retry.backoff.ms = 100
sasl.kerberos.kinit.cmd = /usr/bin/kinit
buffer.memory = 33554432
timeout.ms = 30000
key.serializer = class org.apache.kafka.common.serialization.ByteArraySerializer
sasl.kerberos.service.name = null
sasl.kerberos.ticket.renew.jitter = 0.05
ssl.keystore.type = JKS
ssl.trustmanager.algorithm = PKIX
block.on.buffer.full = false
ssl.key.password = null
max.block.ms = 60000
sasl.kerberos.min.time.before.relogin = 60000
connections.max.idle.ms = 540000
ssl.truststore.password = null
max.in.flight.requests.per.connection = 5
metrics.num.samples = 2
client.id = 
ssl.endpoint.identification.algorithm = null
ssl.protocol = TLS
request.timeout.ms = 30000
ssl.provider = null
ssl.enabled.protocols = [TLSv1.2, TLSv1.1, TLSv1]
acks = 1
batch.size = 16384
ssl.keystore.location = null
receive.buffer.bytes = 32768
ssl.cipher.suites = null
ssl.truststore.type = JKS
security.protocol = PLAINTEXT
retries = 0
max.request.size = 1048576
value.serializer = class org.apache.kafka.common.serialization.ByteArraySerializer
ssl.truststore.location = null
ssl.keystore.password = null
ssl.keymanager.algorithm = SunX509
metrics.sample.window.ms = 30000
partitioner.class = class org.apache.kafka.clients.producer.internals.DefaultPartitioner
send.buffer.bytes = 131072
linger.ms = 0

2017-01-12 14:47:09.985 INFO 1- itterSource-1-1 o.a.kafka.common.utils.AppInfoParser : Kafka版本: 0.9.0.1

但是生产者不断抛出以下异常,

代码语言:javascript
复制
2017-01-12 14:47:42.196 ERROR 1 --- [ad | producer-3] o.s.k.support.LoggingProducerListener    : Exception thrown when sending a message with key='null' and payload='{-1, 1, 11, 99, 111, 110, 116, 101, 110, 116, 84, 121, 112, 101, 0, 0, 0, 12, 34, 116, 101, 120, 116...' to topic twitter-source-test:
org.apache.kafka.common.errors.TimeoutException: Batch Expired

我可以从我的码头集装箱传真到经纪人192.168.127.188:9092和2181。另外,我的kafka服务器是,而不是码头容器

看到了一些解决方案,比如添加'advertised.host.name‘,但是不起作用,或者这是我给env提供支持的正确方式。

有什么帮助吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-11-29 10:35:23

分享修复。

在server.properties中设置侦听器可以解决这个问题。例:listeners = PLAINTEXT://your.host.name:9092

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41609877

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档