实验前提:
安装twisted
安装tornado
实验1: 对比twisted的两种网络模型select模式和epoll模式的web服务器(单线程)与tornado的web服务器(单线程)的性能差异
twisted select模式
from twisted.internet import selectreactor
selectreactor.install()
from twisted.internet import reactor
from twisted.web import server, resource
class Simple(resource.Resource):
isLeaf = True
def render_GET(self, request):
return "<html>Hello, world!</html>"
import sys
print sys.modules['twisted.internet.reactor']
site = server.Site(Simple())
reactor.listenTCP(8080, site)
reactor.run()
twisted epoll模式
from twisted.internet import epollreactor
epollreactor.install()
from twisted.internet import reactor
from twisted.web import server, resource
class Simple(resource.Resource):
isLeaf = True
def render_GET(self, request):
return "<html>Hello, world!</html>"
import sys
print sys.modules['twisted.internet.reactor']
site = server.Site(Simple())
reactor.listenTCP(8080, site)
reactor.run()
tornado 服务器
import tornado.ioloop
import tornado.web
import time
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.write("Hello, world")
#time.sleep(0.5)
pass
def post(self):
pass
application = tornado.web.Application([
(r"/", MainHandler),
])
if __name__ == "__main__":
application.listen(8080)
tornado.ioloop.IOLoop.instance().start()
在本机使用ab命令进行压测
ab -c 5 -n 10000 http://localhost:8080/
测试结果:
类型 | request/sec |
---|---|
tornado | 1469.23 |
twisted-select | 1148.36 |
twisted-epoll | 1101.66 |
在http的请求处理逻辑中加入消耗CPU的浮点运算,,结果近似
a = 123.45
for i in range(1000):
a = a * a
类型 | request/sec |
---|---|
tornado | 843.39 |
twisted-select | 735.16 |
twisted-epoll | 709.41 |
结论: tornado会优先使用epoll模型,但是其处理速度明显超过twisted
但对于twisted使用epoll模型速度反不如使用select模型,实在令人费解。