python简单操作kafka

python操作kafkakafka命令行操作# 创建主题kafka-topics.sh --zookeeper localhost:2181 --create --replication-factor 1 --partitions 3 --topic userlog# 查看所有主题kafka-topics.sh --zookeeper localhost:2181 --list# 查看主题kafka-topics.sh --zookeeper localhost:2181 --describ
摘要由CSDN通过智能技术生成

python操作kafka

kafka命令行操作

# 创建主题
kafka-topics.sh --zookeeper localhost:2181 --create --replication-factor 1 --partitions 3 --topic userlog
# 查看所有主题
kafka-topics.sh --zookeeper localhost:2181 --list
# 查看主题
kafka-topics.sh --zookeeper localhost:2181 --describe --topic userlog
# 创建生产者
kafka-console-producer.sh --broker-list IP:9092 --topic userlog
# 创建消费者
kafka-console-consumer.sh --bootstrap-server IP:9092 --from-beginning --topic userlog

利用python代码使用kafka

python生成producer

from kafka import KafkaProducer

# 创建生产者
producer = KafkaProducer(bootstrap_servers='IP:9092')
msg = '哈哈'.encode('utf-8')  # 发送内容,必须是bytes类型
# 可以通过send方法中的partition参数指定分区传入
producer.send('userlog', msg, partition=0)
producer.close()

这里的producer.close()非常关键, 如果不写,主线程不会等待producer发送完消息,这样的话,如果主线程结束,producer还没发送完消息,就会发送失败,但是代码不会报错,消息又没进入到kafka,所以一定要加上,这样主线程就会等待producer发送完消息

传入json数据

from kafka import KafkaProducer
import json

# 连接kafka
producer = KafkaProducer(bootstrap_servers='IP:9092',
                         # 传入json数据时,可用value_serializer参数进行处理
                         value_serializer=lambda x: json.dumps(x, ensure_ascii=False).encode('utf-8')
                         )
msg = {
   "text":</
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值