内容简介:翻译自:https://stackoverflow.com/questions/46667697/block-jupyter-notebook-cell-execution-till-specific-message-received
实现异步的分布式计算引擎,它与jupyter notebook兼容.该系统应该基于“推送通知”方法,这使得(几乎,我希望)不可能允许用户等待特定的计算结果(即,给定笔记本单元的块执行直到具有预期结果的消息被传递).确切地说,我试图:
>将新任务添加到jupyter notebook事件循环(任务定期检查特定msg是否已在循环中到达,当msg到达时中断)
>阻止当前单元格等待任务完成.
>仍然能够处理传入的消息(使用RabbitMQ,Pika,从 http://pika.readthedocs.io/en/0.10.0/examples/asynchronous_consumer_example.html 略微修改的代码)
我准备了笔记本来展示我的问题: https://github.com/SLEEP-MAN/RabbitMQ_jupyterNotebook_asyncio
有任何想法吗?是否有可能(可能是一些IPython / IpyKernel魔法;>?),或者我必须将我的方法改变180度?
您的问题是您将两个不同的循环混合在一起.这就是为什么它不起作用.你需要做一些改变.
使用AsyncioConnection而不是TornadoConnection
return adapters.AsyncioConnection(pika.URLParameters(self._url), self.on_connection_open)
接下来你需要删除下面的行
self._connection.ioloop.start() #throws exception but not a problem...
因为你的循环已经在连接中启动了.然后你需要使用下面的代码等待
loop = asyncio.get_event_loop() loop.run_until_complete(wait_for_eval())
现在它有效
翻译自:https://stackoverflow.com/questions/46667697/block-jupyter-notebook-cell-execution-till-specific-message-received
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 阻止某个 NuGet 包意外升级
- 阻止恶意SSL通信六要点
- ios – 阻止递归和打破保留周期
- 如何阻止别人非法链接你网站的图片?
- vue拦截(阻止)浏览器后退事件
- 突破前端反调试:阻止页面不断 debugger
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入理解计算机系统
Randal E.Bryant、David O'Hallaron / 龚奕利、雷迎春 / 中国电力出版社 / 2004-5-1 / 85.00元
从程序员的视角,看计算机系统! 本书适用于那些想要写出更快、更可靠程序的程序员。通过掌握程序是如何映射到系统上,以及程序是如何执行的,读者能够更好的理解程序的行为为什么是这样的,以及效率低下是如何造成的。粗略来看,计算机系统包括处理器和存储器硬件、编译器、操作系统和网络互连环境。而通过程序员的视角,读者可以清晰地明白学习计算机系统的内部工作原理会对他们今后作为计算机科学研究者和工程师的工作有......一起来看看 《深入理解计算机系统》 这本书的介绍吧!