请教一下大神,为什么我的 tornado 服务器性能这么低下? windows 上 jmeter 测试 centos7 虚拟机,

2018-07-24 20:08:28 +08:00
 BackToPast
如题,windows 上 jmeter 测试 centos7 虚拟机,10 秒钟 5000 用户,90line 达到 9000ms,还有 5%的 error,代码如下:

class IndexHandler(tornado.web.RequestHandler): # 首页请求
@tornado.web.asynchronous
@tornado.gen.coroutine
def get(self):
self.render('index.html')
self.finish()
1542 次点击
所在节点    Python
3 条回复
BackToPast
2018-07-24 20:14:05 +08:00
大神~
sujin190
2018-07-26 22:48:03 +08:00
事实上,异步的 tornado 虽然可以支持超高并发,但是受限 python 性能问题,在很高的并发情况下,会因为协程调度栈非常长,调度效率低下,因此其实并不能同时处理很多请求

简单来说就是同时处理 5000 个请求,每个分一点时间,但是谁也无法完成
windows 使用 select,估计 500 并发之后延迟就很高了

还有 tornado.gen.coroutine 包裹就已经是异步了,不需要 tornado.web.asynchronous,用一个就行
mutalisk
2018-08-03 13:29:51 +08:00
@sujin190 windows 下默认估计不是用的 select reactor 吧,是 iocp reactor 吧。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/473798

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX