python aioamqp分布式_带aioamqp的异步RabbitMQ使用者

我想出了一个办法。我不确定这是否是最佳实践,但它正在实现我所需要的。在

而不是做“工作”(在这种情况下,异步睡眠)在回调函数中,我在循环中创建一个新任务,并调度一个单独的co例程来运行do\u work()。大概这是有效的,因为它释放了callback()以立即返回。在

我在Rabbit中加载了几百个不同睡眠计时器的事件,当按下面的代码打印时,它们被交错排列。所以它似乎起作用了。希望这对某人有帮助!在@asyncio.coroutine

def do_work(envelope, body):

yield from asyncio.sleep(int(body))

print("consumer {} recved {} ({})".format(envelope.consumer_tag, body, envelope.delivery_tag))

@asyncio.coroutine

def callback(body, envelope, properties):

loop = asyncio.get_event_loop()

loop.create_task(do_work(envelope, body))

@asyncio.coroutine

def receive_log():

try:

transport, protocol = yield from aioamqp.connect('localhost', 5672, login="login", password="password")

except:

print("closed connections")

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值