Kafka~HelloWorld得来不易

本文分享了在.NET环境下使用Kafka时遇到的消息消费失败问题及其解决方案。通过排查防火墙设置、Zookeeper运行状态和Kafka服务配置,最终发现是因为Kafka仅监听localhost导致消费者无法连接。调整监听IP为虚拟机真实IP并重启Kafka服务后,问题得到解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天连搭了zookeeper和kafka的环境,并部署成功,但在.net驱动的操作下,没有消费成功,原因何在?

  1. 防火墙
  2. zookeeper没运行?
  3. kafka没有公开IP?

第一感觉也就是这向个原因了,于是自己调试了一下,最后分别进行了验证

防火墙

systemctl status firewalld

zookeeper没运行?

netstat -tunlp|egrep 2181

kafka没有公开IP?

$ vi server.properties

通过查看kafka的服务配置文件我们找到了答案,它原来只公开了localhost,而我们的程序是部署到虚拟机上的,所以localhost是访问不通过的,即你的消息者无法消费,而这时我们需要把这个配置文件修改一下,把listeners的绑定IP添加成虚拟机真实的IP,然后重启我们的kafka,就可以了!

bin/kafka-server-stop.sh

bin/kafka-server-start.sh config/server.properties &

最后再次进行C#客户端的测试,令我们心喜的结果自然就出来了!

查看所有topic列表

bin/kafka-topics.sh --zookeeper localhost:2181 --list

 查看指定topic信息

bin/kafka-topics.sh --zookeeper localhost:2181 --describe --topic test

希望通过这篇文章,让大家对kafka,zookeepr,centos有一个学习与了解!

感谢各位的阅读!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值