Mac*_*cki 8 python rabbitmq pika python-asyncio jupyter-notebook
我正在尝试为python实现异步,分布式计算引擎,它与jupyter notebook兼容.该系统应该基于"推送通知"方法,这使得(几乎,我希望)不可能允许用户等待特定的计算结果(即,给定笔记本单元的块执行直到具有预期结果的消息被传递).确切地说,我试图:
我准备好了解决我的问题的笔记本:https://github.com/SLEEP-MAN/RabbitMQ_jupyterNotebook_asyncio
有任何想法吗?是否有可能(可能是一些IPython/IpyKernel魔法;>?),或者我必须将我的方法改为180度?
您的问题是您将两个不同的循环混合在一起。这就是为什么它不起作用。您需要进行一些更改。
使用AsyncioConnection而不是TornadoConnection
return adapters.AsyncioConnection(pika.URLParameters(self._url),
self.on_connection_open)
Run Code Online (Sandbox Code Playgroud)
接下来你需要删除下面的行
self._connection.ioloop.start() #throws exception but not a problem...
Run Code Online (Sandbox Code Playgroud)
因为你的循环已经在连接中启动了。然后你需要使用下面的代码来等待
loop = asyncio.get_event_loop()
loop.run_until_complete(wait_for_eval())
Run Code Online (Sandbox Code Playgroud)
现在可以了
| 归档时间: |
|
| 查看次数: |
589 次 |
| 最近记录: |