生产中有一个特殊场景,如何选择合适的Python WSGI服务器

2013-11-01 11:46:18 +08:00
 dingyaguang117
场景描述:
借口依赖第三方网站,需要即时访问第三方网站解析数据,所以可能长时间阻塞在IO上,甚至最后超时。因此,一个请求返回时间会比较长,几秒甚至十几秒。
目前用的uwsgi。而且我设置的是8个进程每个进程2个线程,也就是说最大同时连接数只有16,而且每个请求处理时间又很长,所以QPS 几乎就是个位数。

请问是不是换成apache使用mod_wsgi会好一点?让最大连接数可以上去
2305 次点击
所在节点    问与答
7 条回复
rrfeng
2013-11-01 12:02:16 +08:00
既然用 WSGI 那就不能用非阻塞模式吧,那就只能多开线程了……
codeframe
2013-11-01 12:06:37 +08:00
用 gunicorn, 然后把 worker_class 配成 gevent 。
http://docs.gunicorn.org/en/latest/configure.html#worker-class
ipconfiger
2013-11-01 12:07:49 +08:00
这个啊,直接用tornado就妥妥的了,标准应用场景
ipconfiger
2013-11-01 12:08:45 +08:00
不过wsgi就算了吧,这个协议标准的同步工作模式。非要用的话,就只有gevent了
dingyaguang117
2013-11-01 23:22:59 +08:00
@ipconfiger 用tornado 的话,是不是要改写程序
ipconfiger
2013-11-01 23:52:23 +08:00
@dingyaguang117 按道理说这种类型的代理应该一袋烟的功夫就改好了
dingyaguang117
2013-11-04 09:58:53 +08:00
@ipconfiger 谢谢 我去看下

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

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

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

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

© 2021 V2EX