gpt4 book ai didi

python - 如何在 Python 中订阅 NATS 主题并继续接收消息?

转载 作者:行者123 更新时间:2023-12-05 08:49:33 32 4
gpt4 key购买 nike

我尝试了下面的示例(来自 this 页面):

nc = NATS()

await nc.connect(servers=["nats://demo.nats.io:4222"])

future = asyncio.Future()

async def cb(msg):
nonlocal future
future.set_result(msg)

await nc.subscribe("updates", cb=cb)
await nc.publish("updates", b'All is Well')
await nc.flush()

# Wait for message to come in
msg = await asyncio.wait_for(future, 1)

但这似乎只对接收一条消息有用。我将如何订阅并继续接收消息?

我也看过 the package example , 但它似乎只是播放对话的双方,然后退出。

最佳答案

您还可以找到一个长期运行的服务示例:https://github.com/nats-io/nats.py/blob/master/examples/service.py

import asyncio
from nats.aio.client import Client as NATS

async def run(loop):
nc = NATS()

async def disconnected_cb():
print("Got disconnected...")

async def reconnected_cb():
print("Got reconnected...")

await nc.connect("127.0.0.1",
reconnected_cb=reconnected_cb,
disconnected_cb=disconnected_cb,
max_reconnect_attempts=-1,
loop=loop)

async def help_request(msg):
subject = msg.subject
reply = msg.reply
data = msg.data.decode()
print("Received a message on '{subject} {reply}': {data}".format(
subject=subject, reply=reply, data=data))
await nc.publish(reply, b'I can help')

# Use queue named 'workers' for distributing requests
# among subscribers.
await nc.subscribe("help", "workers", help_request)

print("Listening for requests on 'help' subject...")
for i in range(1, 1000000):
await asyncio.sleep(1)
try:
response = await nc.request("help", b'hi')
print(response)
except Exception as e:
print("Error:", e)

if __name__ == '__main__':
loop = asyncio.get_event_loop()
loop.run_until_complete(run(loop))
loop.run_forever()
loop.close()

关于python - 如何在 Python 中订阅 NATS 主题并继续接收消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63846385/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com