转自:http://blog.csdn.net/woshiaotian/article/details/17839677
实验前提:
安装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模型,实在令人费解。