安装kafka-python:
C:\anaconda3\Scripts>pip install kafka-python
import datetime
import json
from kafka import KafkaProducer
from kafka import KafkaConsumer
from kafka.errors import KafkaError
'''
使用kafka-python的生产模块
'''
class Kafka_producer():
def __init__(self, bootstrapServers, kafkaTopic):
self.bootstrapServers = bootstrapServers
self.kafkaTopic = kafkaTopic
self.producer = KafkaProducer(bootstrap_servers=self.bootstrapServers)
def sendjsondata(self, params):
try:
parmas_message = json.dumps(params)
producer = self.producer
future = producer.send(self.kafkaTopic, parmas_message.encode('utf-8'))
producer.flush()
recordMetadata = future.get(timeout=10)
print(recordMetadata, datetime.datetime.now().strftime('%Y%m%d%H%M%S'))
except KafkaError as e:
print(e)
'''
使用Kafka-python的消费模块
'''
class Kafka_consumer():
def __init__(self, bootstrapServers, kafkaTopic, groupId):
self.kafkaTopic = kafkaTopic
self.bootstrapServers = bootstrapServers
self.groupId = groupId
self.consumer = KafkaConsumer(self.kafkaTopic, group_id=self.groupId, bootstrap_servers=self.bootstrapServers)
def consume_data(self):
try:
for message in self.consumer:
yield message
except BaseException as e:
print(e)
if __name__ == '__main__':
bootstrapServers = ['ip1:port1', 'ip2:port2', 'ip3:port3']
topicStr = '主题'
print('-' * 20)
print('生产者')
print('-' * 20)
producer = Kafka_producer(bootstrapServers, topicStr)
for id in range(5):
params = '{tst}:{null}---' + str(id)
producer.sendjsondata(params)
print('-' * 20)
print('消费者')
print('-' * 20)
groupId = 'group名称'
consumer = Kafka_consumer(bootstrapServers, topicStr, groupId)
message = consumer.consume_data()
for i in message:
print(i.value)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?