Python发送带key的kafka消息

在Python中发送带有键(key)的Kafka消息,通常会使用`confluent-kafka`或`kafka-python`这样的库。这里我将分别展示如何使用这两个库来实现这个功能。

使用 `confluent-kafka`

首先,确保你已经安装了`confluent-kafka`库。如果没有安装,可以使用pip进行安装:

```bash

pip install confluent-kafka

```

然后,你可以使用以下代码来发送带有键的消息:

```python

from confluent_kafka import Producer

def delivery_report(err, msg):

""" Called once for each message produced to indicate delivery result.

Triggered by poll() or flush(). """

if err is not None:

print(f'Message delivery failed: {err}')

else:

print(f'Message delivered to {msg.topic()} [{msg.partition()}]')

配置生产者

conf = {'bootstrap.servers': 'localhost:9092'}

创建生产者实例

producer = Producer(conf)

消息的键和值

message_key = 'my_key'

message_value = 'Hello, Kafka!'

发送消息

producer.produce('my_topic', key=message_key, value=message_value, callback=delivery_report)

触发所有消息的回调函数

producer.flush()

```

使用 `kafka-python`

同样地,确保你已经安装了`kafka-python`库。如果未安装,可以通过pip安装:

```bash

pip install kafka-python

```

接下来,使用以下代码来发送带有键的消息:

```python

from kafka import KafkaProducer

创建生产者实例

producer = KafkaProducer(bootstrap_servers='localhost:9092',

key_serializer=str.encode,

value_serializer=str.encode)

消息的键和值

message_key = 'my_key'

message_value = 'Hello, Kafka!'

发送消息

producer.send('my_topic', key=message_key, value=message_value)

确保所有消息都已发送

producer.flush()

关闭生产者

producer.close()

```

在这两个例子中,我们创建了一个Kafka生产者,并指定了一个本地运行的Kafka服务器地址(`localhost:9092`)。然后,我们定义了要发送的消息的键和值,并调用了相应的方法来发送消息。对于`confluent-kafka`,我们还设置了一个回调函数来处理消息的交付结果。

请根据你的实际环境调整配置,例如Kafka服务器的地址等。希望这能帮助到你!如果有任何其他问题,请随时提问。

相关推荐
东方不败之鸭梨的测试笔记12 分钟前
多进程、多线程、分布式测试支持-pytest-xdis插件
python
数据龙傲天32 分钟前
API接口性能优化:提升电商数据处理速度的关键
爬虫·python·性能优化·数据分析·api
<e^πi+1=0>1 小时前
Docker搭建kafka环境
docker·kafka
爱吃香蕉的猴哥1 小时前
消息系统之 Kafka
分布式·kafka
Takoony1 小时前
理解 Python ProcessPoolExecutor 的序列化问题:为什么线程锁(threading.Lock)会导致异常?
linux·开发语言·python
道友老李1 小时前
【Python基础】入门(运算、输出、数据类型)
开发语言·python
汝即来归2 小时前
如何实现序列化和反序列化?如何处理对象的生命周期管理?
开发语言·python
豆本-豆豆奶2 小时前
Python 图像处理领域的十一个基础操作
开发语言·图像处理·python
B站计算机毕业设计超人2 小时前
计算机毕业设计Django+Tensorflow音乐推荐系统 音乐可视化 卷积神经网络CNN LSTM音乐情感分析 机器学习 深度学习 Flask
大数据·人工智能·python·机器学习·课程设计·数据可视化·推荐算法
zaim12 小时前
Python 的 Decimal的错误计算
python·error·误差·decimal·精度·getcontext