上图显示了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.