记录一次云服务器使用docker搭建kafka的过程

创建网络

一定要将zookeeper注册中心与kafka建在一个network中,不然在springboot 集成 kakfa的demo测试代码中进行消息发送时会超时,报错: E x c e p t i o n t h r o w n w h e n s e n d i n g a m e s s a g e w i t h k e y = ' n u l l ' Exception thrown when sending a message with key='null' Exceptionthrownwhensendingamessagewithkey='null'

bash 复制代码
docker network create zk-ka-net

docker启动zookeeper注册中心

bash 复制代码
docker pull wurstmeister/zookeeper
bash 复制代码
docker run -d --name zookeeper --network zk-ka-net -p 2181:2181 -t wurstmeister/zookeeper

docker启动kafka服务

bash 复制代码
docker pull wurstmeister/kafka
bash 复制代码
docker run -d --name kafka -p 9092:9092 --network zk-ka-net --link zookeeper:zookeeper -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://外网ip:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 wurstmeister/kafka

基本使用

  1. 进入容器
bash 复制代码
docker exec -it ${CONTAINER ID} /bin/bash
  1. 进入kafka的bin目录下
bash 复制代码
echo $PATH
cd /opt/kafka/bin
  1. 创建topic
bash 复制代码
kafka-topics.sh --create --zookeeper zookeeper:2181 --replication-factor 1 --partitions 1 --topic my_topic
  1. 运行生产者
bash 复制代码
kafka-console-producer.sh --broker-list 外网ip:9092 --topic my_topic

6.消费topic

bash 复制代码
kafka-console-consumer.sh --bootstrap-server 外网ip:9092 --from-beginning --topic my_topic

springboot 集成 kakfa代码:https://github.com/ZYNORl/project-demo/tree/main

附带一个本地启动的docker命令
bash 复制代码
docker run -d --name kafka -p 9092:9092 --link zookeeper:zookeeper -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://127.0.0.1:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 wurstmeister/kafka
相关推荐
of Watermelon League39 分钟前
SpringBoot集成Flink-CDC,实现对数据库数据的监听
数据库·spring boot·flink
Aurorar0rua41 分钟前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
Cosmoshhhyyy1 小时前
《Effective Java》解读第49条:检查参数的有效性
java·开发语言
eRTE XFUN2 小时前
docker 安装 mysql
mysql·adb·docker
布谷歌2 小时前
常见的OOM错误 ( OutOfMemoryError全类型详解)
java·开发语言
eLIN TECE2 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
老神在在0012 小时前
Spring Bean 的六种作用域详解
java·后端·spring
仙草不加料2 小时前
互联网大厂Java面试故事实录:三轮场景化技术提问与详细答案解析
java·spring boot·微服务·面试·aigc·电商·内容社区
程序员老邢2 小时前
【技术底稿 19】Redis7 集群密码配置 + 权限锁死 + 磁盘占满连锁故障真实排查全记录
java·服务器·经验分享·redis·程序人生·微服务
落魄江湖行3 小时前
基础篇一 Java 有了 int 为什么还要 Integer?它们到底差在哪?
java·面试·八股文