Python发kafka消息

要在Python中向Kafka发送消息,你可以使用`kafka-python`库。首先,你需要安装这个库。如果你还没有安装它,可以通过pip来安装:

```bash

pip install kafka-python

```

接下来是一个简单的例子,展示如何创建一个生产者(Producer)并向Kafka主题(Topic)发送消息。

发送字符串消息

```python

from kafka import KafkaProducer

import json

初始化Kafka生产者

producer = KafkaProducer(

bootstrap_servers=['localhost:9092'], # Kafka服务器地址

value_serializer=lambda x: json.dumps(x).encode('utf-8') # 序列化函数

)

发送一条消息到名为 'my-topic' 的主题

producer.send('my-topic', value='Hello, World!')

确保所有消息都被发送出去

producer.flush()

关闭生产者连接

producer.close()

```

发送JSON格式的消息

如果你想发送更复杂的数据结构,比如字典,可以使用JSON序列化:

```python

发送JSON格式的消息

data = {'key': 'value', 'another_key': 42}

使用已经定义的生产者发送消息

producer.send('my-topic', value=data)

同样需要flush和close

producer.flush()

producer.close()

```

异步发送消息

KafkaProducer默认是异步发送消息的,即`send()`方法会立即返回而不会等待消息被成功发送。你可以通过回调函数来处理发送结果:

```python

def on_send_success(record_metadata):

print(f'Message sent to topic {record_metadata.topic} at offset {record_metadata.offset}')

def on_send_error(excp):

print(f'I am an errback {excp}')

handle exception

发送消息并附加回调

future = producer.send('my-topic', value='Another message')

future.add_callback(on_send_success)

future.add_errback(on_send_error)

阻塞直到所有消息发送完成

producer.flush()

关闭生产者连接

producer.close()

```

请确保你已经正确配置了Kafka集群,并且在代码中指定了正确的`bootstrap_servers`。如果你的Kafka集群运行在不同的机器上或端口不是9092,请相应地调整连接设置。此外,如果你的主题有特定的分区策略或者需要指定键值,也可以在`send`方法中提供`key`参数和其他选项。

相关推荐
morris1315 分钟前
【python】PyPDF2操作pdf
python·pdf·pypdf2
web1376560764310 分钟前
【Python】网络爬虫——词云wordcloud详细教程,爬取豆瓣最新评论并生成各式词云
爬虫·python·信息可视化
PeterClerk16 分钟前
深度学习-自监督学习总结
图像处理·人工智能·pytorch·python·深度学习·aigc·自监督学习
数据攻城小狮子38 分钟前
深入探索Python机器学习算法:监督学习(线性回归,逻辑回归,决策树与随机森林,支持向量机,K近邻算法)
python·算法·决策树·机器学习·支持向量机·sklearn·k近邻算法
互联网搬砖老肖1 小时前
DeepSeek如何快速开发PDF转Word软件
python·ai编程
一杯咖啡半杯糖1 小时前
Python安装环境变量
开发语言·python
量化投资技术1 小时前
【量化策略】均值回归策略
python·量化交易·量化·量化投资·qmt·miniqmt
猿毕设2 小时前
【FL0080】基于SSM和微信小程序的宠物寄养平台
java·spring boot·后端·python·微信小程序·小程序·宠物
Shepherdppz2 小时前
python量化交易——金融数据管理最佳实践——qteasy创建本地数据源
python·金融·php
万年枝2 小时前
torch中维度操作总结(repeat,squeeze,unsqueeze,flatten,transpose)
pytorch·python·深度学习