python发送kafka消息_用带有烧瓶的kafkapython发送通知

本文介绍了如何在Python中结合Flask(烧瓶)和Kafka库来构建一个通知服务。作者已经成功地独立运行了消费者和生产者,但在尝试将消费者集成到Flask应用中时遇到问题。目前的架构包括远程服务器上的Zookeeper和Kafka,以及使用Firebase发送通知。文章讨论了在不依赖HTTP请求的情况下在Flask应用内部操作Kafka消费者的挑战,并提到了遇到的'RuntimeError: Working outside of request context'错误。
摘要由CSDN通过智能技术生成

Ql0C7.png

上图显示了im试图实现的当前架构。目前,我正在一个远程服务器上运行zookeeper和kakfa(两者都是新手),这个通知服务应用程序是使用flask(kafka python)和其他应用程序App1构建的。Appn将充当生产者。

好吧,我能独立经营消费者和生产者,这两个部门运作得很好。

但我试图将消费者集成到通知服务中,但什么也没发生。在app.py

def send_notification_from_consumer(payload):

# sending notification using firebase

if __name__ == '__main__':

app.run(host='127.0.0.1', port=8000, debug=True)

^{pr2}$

producer.py

from kafka import KafkaProducer

import json

producer = KafkaProducer(bootstrap_servers=['remote_server_ip:9092'],

value_serializer=lambda m: json.dumps(m).encode('utf-8'))

def on_send_success(record_metadata):

print(record_metadata.topic)

print(record_metadata.partition)

print(record_metadata.offset)

def on_send_error(excp):

log.error('I am an errback', exc_info=excp)

for i in range(1):

name = {"phone_number_list": ["1234567890", "1234567891"],

"payload": {"title": "Hello from another ",

"description": "Test notification by notification service",

"banner_image": "", "id": 123, "action": {"type": "web", "button_label": "", "link": ""},

"app_name": "app_name"}

}

producer.send('send-notification', name).add_callback(on_send_success).add_errback(on_send_error)

是否可以在不使用HTTP请求的情况下调用消费者,因为我只是在kafka消费者中调用send_notification_from_consumer。正确的方法是什么?我该如何在烧瓶内操作消费者呢。在

我也试过这个solution

但我收到了这个错误。这个解决方案可以扩展吗?在RuntimeError: Working outside of request context.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值