一、起初无非就是更改server.properties中的配置,以下三项
1.14.247.152的server.properties
broker.id=0
log.dirs=/home/chentongchuan/test/kafka/kafka_2.12-3.0.0/datas
zookeeper.connect=1.14.247.152:2181,159.75.241.252:2181,112.74.188.40:2181/kafka
159.75.241.252的server.properties
broker.id=1
log.dirs=/test/kafka/kafka_2.12-3.0.0/datas
zookeeper.connect=1.14.247.152:2181,159.75.241.252:2181,112.74.188.40:2181/kafka
112.74.188.40的server.properties
broker.id=2
log.dirs=log.dirs=/root/test/kafka/kafka_2.12-3.0.0/datas
zookeeper.connect=1.14.247.152:2181,159.75.241.252:2181,112.74.188.40:2181/kafka
二、分别在三台服务器的bin目录下启动kafka
./kafka-server-start.sh -daemon ../config/server.properties
三、jps命令查看状态启动成功后,连接kafka并创建topics
kafka-topics.sh --bootstrap-server 1.14.247.152:9092 --create --partitions 1 --replication-factor 3 --topic first
报错:
Error while executing topic command : Timed out waiting for a node assignment. Call: createTopics
[2022-03-21 10:43:47,051] ERROR org.apache.kafka.common.errors.TimeoutException: Timed out waiting for a node assignment. Call: createTopics
(kafka.admin.TopicCommand$)
大概意思是等待分配结点超时。
查了网上博客:
由于配置的时候直接使用的IP,所以也就无需配置映射关系了。所以我尝试了办法1:
advertised.host.name=1.14.247.152
advertised.port=9092
还是同样的超时问题。
又返回server.properties查看:发现在32行左右有这段话
#Hostname and port the broker will advertise to producers and consumers. # If not set, it uses the value for "listeners" if configured.
# Otherwise, it will use the value returned from
# java.net.InetAddress.getCanonicalHostName().
# advertised.listeners=PLAINTEXT://yourhostname:9092
大概意思是:
代理将向生产者和消费者发布主机名和端口。 如果没有设置,则使用“listeners”的值。 否则,它将使用从java.net.InetAddress.getCanonicalHostName()返回的值。
于是删除advertised.host.name和advertised.port,在三台服务器配置:
advertised.listeners=PLAINTEXT://1.14.247.152:9092
信心满满,启动,连接kafka并创建topics,再次出现相同的超时异常。
由于之前三个服务器,只有两个服务器开了9092端口(阿里/腾讯云安全组规则 + 防火墙关闭,或阿里/腾讯云安全组规则 + 防火墙开放9092端口),此时马上开通所有服务器的9092端口,成功:
四、为了验证究竟是配置的问题还是端口未开放的问题
在三台服务器9092端口都开放的情况下:
1、去掉advertised.listeners,加上advertised.host.name和advertised.port:成功
2、去掉advertised.host.name和advertised.port,加上advertised.listeners:成功
3、去掉advertised.host.name和advertised.port、advertised.listeners:成功文章来源:https://www.toymoban.com/news/detail-418505.html
结论:不管有没有指定主机和端口,只要端口有开放即可。advertised.xxx其实是代理将向生产者和消费者发布主机名和端口。没有配置的时候,底层会自动通过getCanonicalHostName()来获取。如果配置了主机名,还需要在host文件中配置映射。文章来源地址https://www.toymoban.com/news/detail-418505.html
到了这里,关于部署kafka集群后创建主题超时Timed out waiting for a node assignment. Call:createTopics (kafka.admin.TopicCommand的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!