单独计算机上的Kafka制作人和消费者无法通信

时间:2018-05-18 18:45:10

标签: apache-kafka apache-zookeeper kafka-consumer-api kafka-producer-api

我正在使用kafka_2.11-1.1.0。这是我的server.properties文件:

broker.id=1
num.network.threads=3
num.io.threads=8
socket.send.buffer.bytes=102400
socket.receive.buffer.bytes=102400
socket.request.max.bytes=104857600
log.dirs=/tmp/kafka-logs
num.partitions=1
num.recovery.threads.per.data.dir=1
offsets.topic.replication.factor=1
transaction.state.log.replication.factor=1
transaction.state.log.min.isr=1
log.retention.hours=168
log.segment.bytes=1073741824
log.retention.check.interval.ms=300000
zookeeper.connect=192.168.1.110:2181,192.168.1.64:2181
zookeeper.connection.timeout.ms=6000
group.initial.rebalance.delay.ms=0

在第二台计算机上,broker.id = 2。我通过在命令提示符下键入ipconfig并使用一台计算机上的以太网适配器本地连接下的IPv4地址和另一台计算机上的无线LAN适配器Wi-Fi下的IPv4地址获得了zookeeper.connect行的ip号。

我在每台计算机上运行这些命令(对于跟随的人,在运行第二台计算机之前在两台计算机上运行第一个):

bin\windows\zookeeper-server-start.bat config\zookeeper.properties
bin\windows\kafka-server-start.bat config\server.properties

在第一台计算机上,我创建了一个主题并启动了一个生产者控制台:

bin\windows\kafka-topics.bat --create --zookeeper 192.168.1.110:2181 --replication-factor 2 --partitions 1 --topic test
bin\windows\kafka-console-producer.bat --broker-list 192.168.1.110:2181 --topic test

在第二个问题上,我启动了一个消费者控制台:

bin\windows\kafka-console-consumer.bat --bootstrap-server 192.168.1.64:2181 --topic test

当我尝试发送消息时,消费者没有收到消息。每台计算机上的zookeeper服务器控制台通过以下消息循环,但每个IP值对应于其各自的PC,并且每个循环的端口号增加一个(大约每秒一次):

INFO Accepted socket connection from /192.168.1.110:55371 (org.apache.zookeeper.server.NIOServerCnxnFactory)
WARN Exception causing close of session 0x0 due to java.io.EOFException (org.apache.zookeeper.server.NIOServerCnxn)
INFO Closed socket connection for client /192.168.1.110:55371 (no session established for client) (org.apache.zookeeper.server.NIOServerCnxn)

在制作人控制台中,一分钟后收到此错误:

ERROR Error when sending message to topic test with key: null, value: 6 bytes with error: (org.apache.kafka.clients.producer.internals.ErrorLoggingCallback)
org.apache.kafka.common.errors.TimeoutException: Failed to update metadata after 60000 ms.

我该如何解决这个问题?任何帮助将不胜感激。

更新 - 已解决 - 由Victor提供:

变化:

bin\windows\kafka-console-producer.bat --broker-list 192.168.1.110:2181 --topic test

bin\windows\kafka-console-consumer.bat --bootstrap-server 192.168.1.64:2181 --topic test

要:

bin\windows\kafka-console-producer.bat --broker-list 192.168.1.110:9092 --topic test

bin\windows\kafka-console-consumer.bat --bootstrap-server 192.168.1.64:9092 --topic test

更新2

对于正在关注此事来设置两台Kafka计算机的人 - 我发现这种方法并不总是有效。我后来发现的永久解决方案是为两台计算机使用相同的IP。我使用了以太网连接的计算机的IP,这恰好是与制作人的连接。

1 个答案:

答案 0 :(得分:3)

我相信你必须向生产者传递一份Kafka经纪人名单而不是Zookeeper法定人数:

所以改变这个:

bin\windows\kafka-console-producer.bat --broker-list 192.168.1.110:2181

对于这样的事情:

bin\windows\kafka-console-producer.bat --broker-list 192.168.1.110:9092

(我假设你在那里运行你的Kafka服务器)

我遇到了类似的错误,用Spark Streaming写信给Kafka:

Error connecting to Zookeeper with Spark Streaming Structured