docker安装kafka以及Python脚本生产消费
docker安装kafka以及Python脚本生产消费
1、kafka需要zookeeper管理,所以需要先安装zookeeper。
docker pull zookeeper:3.6
1.1、启动zookeeper
docker run -d --name zookeeper --publish 2181:2181 --volume /etc/localtime:/etc/localtime zookeeper:3.6
2、拉取kafka镜像
docker pull wurstmeister/kafka:2.12-2.5.0
2.1、启动kafka
docker run -d --name kafka --publish 9092:9092 --link zookeeper --env KAFKA_ZOOKEEPER_CONNECT=172.25.38.172:2181 --env KAFKA_ADVERTISED_HOST_NAME=172.25.38.172 --env KAFKA_ADVERTISED_PORT=9092 --volume /etc/localtime:/etc/localtime wurstmeister/kafka:2.12-2.5.0
2.2、备注:
KAFKA_ZOOKEEPER_CONNECT 配置本地的 ES 的地址,KAFKA_ADVERTISED_HOST_NAME 配置 kafka 所在服务器的地址,这里我都是本机 IP(需要把IP地址换成你的IP地址进行调试)
3、生产者脚本
# 生产者
import datetime
import json
from kafka import KafkaProducer
if __name__ == '__main__':
topic = 'test'
producer = KafkaProducer(bootstrap_servers='172.25.38.172:9092',
value_serializer=lambda m: json.dumps(m).encode("utf-8")) # 连接kafka
# 参数bootstrap_servers:指定kafka连接地址
# 参数value_serializer:指定序列化的方式,我们定义json来序列化数据,当字典传入kafka时自动转换成bytes
# 用户密码登入参数
# security_protocol="SASL_PLAINTEXT"
# sasl_mechanism="PLAIN"
# sasl_plain_username="maple"
# sasl_plain_password="maple"
for i in range(100):
data = {"num": i, "ts": datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")}
producer.send(topic, data)
producer.close()
4、消费者脚本
import json
from kafka import KafkaConsumer
if __name__ == '__main__':
consumer = KafkaConsumer("test",
bootstrap_servers="172.25.38.172:9092",
group_id='test13', )
data = []
for msg in consumer:
info = msg.value.decode("utf-8")
data = json.loads(info)
print(data)
5、补充
5.1、代码生产消息或者消费消息失败时,可以先进入容器,查看是否kafka可用
5.1.1、进入容器
docker exec -it kafka bash
5.1.2、切换到kafka目录
cd opt/kafka
5.1.3.生产消息
bin/kafka-console-producer.sh --broker-list 172.25.41.126:9092 --topic mykafka
5.1.4.查看Topic
bin/kafka-topics.sh --list --zookeeper 172.25.41.126:2181
5.1.5.消费消息
bin/kafka-console-consumer.sh --bootstrap-server 172.25.41.126:9092 --topic mykafka --from-beginning
参考:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏