- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有两个 Tornado 进程 X
和 Y
。 X
中的处理程序处理 post 请求,当这样的请求到达时,除了在 X
中进行更改外,我还想更改存储在 Y 中的一些变量
。
我想使用 Redis
的 PUB/SUB 来做到这一点。很明显,在 X
的处理程序中,我需要向“Y”订阅的 channel 发布消息。
Y
中的这个订阅应该是长期运行的,这样每当有消息发布到 channel 时,Y
中的内容就会自动更新内存中的变量。但是,我不清楚如何在 Y
中实现此订阅和由此产生的更新,因为它不可能是一个普通的处理程序。我计划为此使用异步 redis 客户端 tornado-redis
,如果这有什么不同的话。
一些例子会很有帮助!
最佳答案
这不是 Redis PUB/SUB 解决方案,而是替代方案。如果您的堆栈上已经有 Redis,您不妨使用它(或者更好的消息队列)。
最简单的方法是在 Y 中为此设置一个 tornado.web.RequestHandler
。当 X 需要进行更改时,让 X 向 Y 发送一个 HTTPRequest。有效负载可以是 JSON、表单-编码,二进制。
在 Y 中创建一个套接字,绑定(bind)它并添加 IOLoop.add_handler
监听该套接字并使用 callback
运行。当 X 需要进行更改时,让它连接到那个套接字。 (有效载荷可以是 JSON、二进制)。如果您需要发送消息,这将需要一个小套接字接受和读取。
不用说,两者都应该在防火墙后面。
关于redis - 使用redis pub/sub连接Tornado进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14405215/
根据一些谷歌搜索,我安装了以下错误处理程序。然而,似乎返回 http 500 的 python 异常并没有被这些东西捕获,尽管 404 是这样。通过我在下面的代码中留下的打印语句,我可以看到它没有命中
我刚刚意识到 WebSocketHandler.write_message() 返回一个 Future。我以前没有在我的函数中产生过这个函数: @tornado.gen.coroutine
这是我的 Tornado 文件:: from tornado.wsgi import WSGIContainer from tornado.ioloop import IOLoop from torn
class MainHandler(BaseHandler): @tornado.web.authenticated def get(self): self.rende
我正在尝试使用 AsyncHTTPTestCase 测试 Tornado .我想测试标有 @tornado.web.authenticated 注释的处理程序。因为此处理程序需要身份验证,所以我们必须
我正在使用 Tornado Web Server (版本 4.1)使用 Python 2.7 创建 REST Web 应用程序。我的请求处理程序之一 (web.RequestHandler) 使用多部
我想知道tornado 的内部工作流程,并且看过this article ,很好,但我就是想不通 ioloop.py里面有这样一个函数 def add_handler(self, fd, handle
如何遍历从 Python/Tornado 处理程序传递到 Tornado 模板的字典? 我试过 {% for key, value in statistics %}
我有一个 Tornado 后端,为 Angular 前端提供服务。更新数据库时,tornado api 不会获取更新的数据。它仅在我重新启动服务器后出现。有人可以帮我解决这个问题吗?我希望获取的数据能
我尝试使用自定义的 WSGIContainer 来处理异步操作: from tornado import httpserver, httpclient, ioloop, wsgi, gen @gen.
from tornado.web import RequestHandler class HelloWorldHandler(RequestHandler): def get(self):
Pylint 遇到 @tornado.web.authenticated 时崩溃 class Handler1(tornado.web.RequestHandler): def get(sel
经过 tornado.gen documentation有人可以帮我理解 tornado.gen.coroutine 和 tornado.gen.engine 之间的确切区别 最佳答案 正如 gen.
代码如下: from tornadoredis import Client from tornado.ioloop import IOLoop from tornado.gen import coro
我有一个 tornado.websocket.WebSocketHandler 的子类。在该类中,我有一个方法使用 Django ORM 从子类模型中获取用户:django.contrib.auth.
我是 ssl 之类的新手,我已经使用 openssl 生成了自签名证书。 openssl req -newkey rsa:2048 -nodes -keyout key.pem -x509 -days
我已经从 tornado 4.2 移动到 tornado 6.0.3,我得到了错误 AttributeError:模块“tornado.web”没有属性“异步” 根据 tornado v6 seems
我一直在关注此 ( https://developer.ibm.com/tutorials/se-distributed-apps-zeromq-part2/) 教程,以设置使用 CurveZMQ 加
我在使用tornado-celery整合tornado和celery时,出现错误:``` traceback (most recent call last): File "/usr/local/l
我正在使用 Tornado 与 twitter 等第三方进行身份验证。 我的登录处理程序看起来像这样 class AuthLoginHandler(BaseHandler, tornado.auth.
我是一名优秀的程序员,十分优秀!