python - Tornado 和基于Python的守护进程之间的最佳通信方式是什么?

标签 python sockets tornado

我使用 Tornado 作为网络服务器。我用 Python 编写了一些守护进程,它们在服务器硬件中运行。有时,Web 服务器需要向守护进程发送一些数据并接收一些计算结果。有两个工作: 1. 异步模式:服务器向守护进程发送一些数据,并且很快不需要结果。我可以使用消息队列来完美地做到这一点吗? 2. 同步模式:服务器向守护进程发送数据,守护进程会等待得到结果。我应该使用套接字吗?

那么,tornado 和基于 Python 的守护进程之间最好的通信方式是什么?

最佳答案

ZeroMQ可以用于此目的。它具有用于不同目的的各种套接字,并且速度足够快,永远不会成为您的瓶颈。对于异步,您可以使用 DEALER/ROUTER 套接字,对于严格同步模式,您可以使用 REQ/REP 套接字。

您可以为此使用 python 绑定(bind) --> http://www.zeromq.org/bindings:python

对于异步模式,您可以尝试 zguide chapter 3 Router-to-dealer async routing 中的类似操作:

就您而言,图中的“客户端”将是您的 Web 服务器,而您的守护进程将是“工作人员”。

zguide router-dealer-async-routing

<小时/>

对于同步,您可以尝试 simple request-reply broker或一些变体来满足您的需要。

a simple request-reply-broker

上图显示了 REQ/REP 套接字上严格同步的发送/接收周期。通读 zguide 链接以了解其工作原理。他们的页面上还有一个 python 代码片段。

关于python - Tornado 和基于Python的守护进程之间的最佳通信方式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10666877/

相关文章:

apache - 如何使用apache重定向到docker容器

python - 导入错误: No module named tflearn

python - 不重叠的圆检测

node.js - 开发服务器和 API 之间的 ECONNRESET 代理错误

asynchronous - Tornado 异步处理程序

python - Couchbase 的 Twisted API 不适用于 Python Tornado

python - 正则表达式意外结束

python - 如何在 Python 中获取依赖注入(inject)对象的每个测试用例范围?

php - PHP和C++之间的套接字连接

sockets - 是否有一个围绕winsock内核的套接字包装器(WSK,而不是winsock2)?