- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对Tornado的了解很少,在部署方面,最好将Nginx用作具有Tornado进程数量的负载平衡器。
扭曲呢?是一样的吗?
最佳答案
如果我正确地跟踪了您的问题,您似乎会问:“龙卷风是否应该成为Nginx的领先者,那么Twisted呢?”
如果那确实是问题的去向,那么它会得到一个“取决于”的答案,但也许以您可能不会想到的方式。从运行时的角度来看,扭曲,龙卷风和Nginx的作用远非同一件事。
所有这三个系统在其内核中使用相同的编程模式。 OO人称其为Reactor模式,这通常也称为异步I / O事件编程,而老式Unix人士将其称为select
风格的事件循环。 (通过select
/ epoll
/ kqueue
/ WaitForMultipleObjects
等完成)
为了建立答案,需要一些背景知识:
Twisted是一个基于Reactor的框架,旨在以最通用的形式编写基于python的异步I / O项目。因此,尽管它对于Web应用程序(通过Twisted Web子模块)非常有用,但对处理串行数据(通过SerialPort子模块)或实现完全不同的网络协议(如ssh)也同样有效。
Twisted在灵活性方面表现出色。如果您需要将许多IO类型粘合在一起,特别是如果要将IO连接到Web,那就太棒了。如remudada答案中所述,它还具有内置的(twistd
)应用程序工具。
作为异步I / O框架,Twisted很少有每周工作。尽管作为一个Web框架(尽管它正在积极地发展),但与诸如Flask之类的插件丰富的框架相比,它确实感觉落后了,而且Tornado肯定比Twisted Web拥有许多Web便利。
Torando是python中基于Reactor的框架,创建该框架是为了以极快的速度服务网页/ webapp(基本上可以像python一样快地投放网页)。编写该程序的人的目标是编写系统的速度如此之快,以使生产代码本身可以是python。
在逻辑上,Tornado核心与Twisted的核心几乎匹配。这些项目的核心是如此相似,以至于在现代发行版中,您可以运行Twisted inside of Tornado或运行Tornado port inside of Twisted。
Tornado一心一意地专注于快速提供网页/ webapp。在大多数应用程序中,它的速度比Twisted Web快20%,但灵活性远远不及支持其他异步I / O用途。它(像Twisted)仍然是基于python的,因此,如果给定的webapp进行过多的基于CPU的工作,其性能将迅速下降。
Nginx是一个基于Reactor的应用程序,旨在为用C语言编写的网页和连接重定向提供服务。虽然Twisted和Tornado使用Reactor模式使python快速运行,但Nginx将事情进行了下一步,并在C语言中使用了该逻辑。
当人们比较Python和C时,他们经常谈论Python慢1.2到100倍。但是,在Reactor模式(正确完成后,大部分时间都花在操作系统上)中,语言效率最低的地方是最小的-只要没有太多的逻辑发生在Reactor之外。
我没有足够的数据来支持这一点,但是我的期望是,您会发现最简单的“ Hello world”(IE服务静态测试)在Tornado上运行的速度不会比在Nginx上运行的速度慢50%以上(Twisted Web为20%)然后平均比龙卷风慢)。
同一事物的速度差异,那会给我们带来什么?
您询问“最好将Nginx用作具有Tornado进程数量的负载平衡器”,因此要回答,我需要问您一个问题。
您是否采用某种方式进行部署,而这对于采用多个内核至关重要?
为了获得超高的异步IO速度,Reactor模式有一个弱点:
每个反应堆只能利用一个过程核心。
您可能会猜到,这种弱点的另一面是,Reactor模式非常高效地使用该内核,如果您有负载,则应该能够使该内核使用率接近100%。
这回到您要询问的设计类型,但是此答案中所有背景的原因是,这些服务(Tornado或Twisted前面的Nginx)的分层仅应利用多核计算机来进行。
如果您在单核系统(最低等级的云服务器或Raspberry Pi等嵌入式平台)上运行,则不应在反应堆前端进行操作。这样做只会使整个系统变慢。
如果您运行的CPU服务比CPU核更多(重载),那么您的工作也会受到影响。
所以:
如果要在单核系统上进行部署:
运行龙卷风或扭曲的一个实例(如果静态页面,则单独运行Nginx)
如果您尝试充分利用多个内核
在应用程序端口上运行Nginx(或双绞),为其余每个处理器核心运行一个Tornado或Twisted实例。
关于twisted - 部署时扭曲和 Tornado 的区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24471521/
以下代码在2端口上监听,当有消息时修改全局dict对象。并且有一个计时器也会修改字典。 d = {} class x(Protocol): def dataReceived(self, dat
Twisted 怎么样?知道函数应该以异步方式执行吗? 异步函数应该返回一个带有call-/errbacks的Deferred(immeadiately),当收到“异步”数据时将被调用。接收到的数据作
我扭曲了服务器。它与插件一起运行。我想根据请求为每个条目编写唯一的前缀。 这意味着当user1发出请求时,它将生成一个唯一的字符串,该字符串将以日志记录为前缀(仅用于此请求)。当user2发出请求时,
我正在使用校准的立体声对进行稀疏重建。这是我一步一步采取的方法: 1- 我使用 MATLAB 中的立体相机校准器应用程序校准了我的立体相机。 2-我拍摄了一对立体图像,并对每个图像进行了不失真处理。
我关注了这个tutorial但我不知道如何从服务器获取响应数据。 class Service(Resource): def render_POST(self, request):
我的网站上有一个页面,它从数据库中获取大量图像并将它们放在一个网格中。 图像的形状和大小各不相同。 我想要做的是显示图像,每个图像都具有相同的宽度和高度,但不会扭曲。 现在我的CSS是 .image{
我正在尝试创建一个简单的代金券程序。 客户端连接到服务器并询问凭证上是否还有时间,如果是,服务器会响应多少时间。 我控制服务器和客户端,客户端也由我编写代码。 现在这就是我的服务器端,客户端是不言自明
假设我通过 TCP 连接快速接收数据。我必须对其进行某种处理。因为我不想阻塞 react 器线程,所以我将处理卸载到后台线程。 数据到达的速度超过了我处理它的速度。如果我将数据放入队列中,队列会无限增
我有一个简单的客户端,它向服务器发送请求并接收响应: from StringIO import StringIO from twisted.internet import reactor fro
我目前正在使用 python/twisted 构建一个 http 服务器。 该服务器必须在另一个 Web 服务器上获取内容,将其存储在本地并将响应发送回客户端。如果遇到 404,它必须尝试提供本地文件
我有一个扭曲的 react 堆监听传入的数据。我有第二个 react 器在特定时间间隔执行 http 请求,将结果发送到第一个 react 器。两者都运行良好。 现在我想把它放在一起在一个 react
我正在尝试使用 ImageMagick 的透视 功能。我看过这些例子,但我无法理解值对应的是什么。我有这段代码: var stream = new MemoryStream(); using (Mag
我有一个应用程序的想法,该应用程序采用每个角落有四个正方形的打印页面,并允许您在至少有两个正方形可见的情况下测量纸上的对象。我希望能够让用户从不太完美的角度拍照,但仍能准确测量物体。 由于我在该领域缺
我试图让用户在文本框中输入文本,并让程序生成所有可能的组合,但最少 3 个字符和最多 6 个字符除外。我不需要像 ' 这样的无用词as'、'a'、'i'、'to' 等弄乱了我的阵列。我还将根据字典检查
给定一个包含 +ve 和 -ve 整数的数组,找出不允许跳过 2 个连续元素的最大总和(即,您必须至少选择其中一个才能向前移动)。 例如:- 10、20、30、-10、-50、40、-50、-1、-3
什么时候应该使用 twisted.python.failure.Failure,什么时候应该使用 twisted.internet.error.ConnectionDone?或者我应该做 twiste
在 Twisted 中有 1 天的经验,我尝试安排消息发送以回复 tcp 客户端: import os, sys, time from twisted.internet import protocol
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
更新:为了便于阅读,这里是如何在 react 器关闭之前添加回调: reactor.addSystemEventTrigger('before', 'shutdown', callable) 原始问题
所以我已经查看了一些涉及使用 python 和 Twisted 框架编写 HTTP 代理的事情。 基本上,就像其他一些问题一样,我希望能够修改将发送回浏览器的数据。也就是说,浏览器请求资源,代理将获取
我是一名优秀的程序员,十分优秀!