赞
踩
要想实现在本地连接服务器的kafka,则必须在远程kafka配置远程连接
默认的 kafka 配置是无法远程访问的,解决该问题有几个方案。
advertised.listeners=PLAINTEXT://IP:9092
注意必须是 ip,不能是 hostname
advertised.listeners=PLAINTEXT://node0:9092
node0 是 hostname,需在 /etc/hosts 中 添加一行
172.16.89.80 node0
局域网一般配置listeners=PLAINTEXT://局域网ip:9092就可以了
但是如果是云服务器,还需要配置advertised.listeners=PLAINTEXT://公网ip:9092,如果是云服务器应该配置两个:
listeners=PLAINTEXT://云服务器局域网ip:9092
advertised.listeners=PLAINTEXT://公网ip:9092
然后 必须在 远程机(要访问 kafka 的机器 windows)上修改 hosts文件,
C:\Windows\System32\drivers\etc\hosts
在末尾加上
IP1 节点1 IP2 节点2
节点名与服务器上的 hostname 相同。
WARN [Consumer clientId=consumer-1, groupId=console-consumer-4184] Connection to node -1 (/172.16.89.80:9092) could not be established. Broker may not be available . (org.apache.kafka.clients.NetworkClient)
kafka 配置 与 console 启动的 ip 不一致,如 配置文件中 listeners=PLAINTEXT://172.16.89.80:9092,启动 是 localhost
kafka.errors.NoBrokersAvailable: NoBrokersAvailable
listeners=PLAINTEXT://172.16.89.80:9092
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。