大家的 Tornado 项目都是如何部署的呢?

2011-08-30 14:56:56 +08:00
 Livid
我目前计划在新项目中用的方案:

通过 Supervisor 控制 Tornado app,然后再通过 nginx 对 Tornado 的输出进行反向代理,其中静态内容(CSS/IMG 等)启用 nginx 的缓存,这样大部分时候 Tornado 只需要关心动态请求即可。

大家的 Tornado 项目都是如何部署的呢?
18356 次点击
所在节点    Tornado
17 条回复
bhuztez
2011-08-30 15:00:58 +08:00
tornado只是处理长连接的吧,直接暴露出去就好了吧?
ratazzi
2011-08-30 15:07:28 +08:00
之前是直接写成守护进程,最简单的那种,然后反向代理,但是挂了后就比较麻烦
xiangjian
2011-08-30 15:13:30 +08:00
也是用supervisor来部署的,看cpu核心数,多开几个端口,使用nginx做负载均衡
Livid
2011-08-30 15:14:42 +08:00
@xiangjian Tornado 就算是到了 2.0 也无法自动利用到多核么?
xiangjian
2011-08-30 15:25:59 +08:00
@Livid 跟tornado无关吧。python脚本就无法使用多核,单进程。
Livid
2011-08-30 15:27:27 +08:00
@xiangjian Thanks. :)
n2n3
2011-08-30 15:30:27 +08:00
ayanamist
2011-08-30 16:04:02 +08:00
@Livid Python由于GIL的限制,多线程的总性能比单线程还要低。多线程只能解决IO时的阻塞问题。实际上Gevent用协程也可以解决。
PyPy有计划剥离GIL,因为用的不是CPython的引用计数的GC。
目前官方是推荐用multiprocess来解决多核利用的问题。
事实上由于Linux上线程和进程的效能差别不大(都可以共享内存),所以这个workaround影响也很小
istef
2011-08-30 16:08:51 +08:00
supervisor + nginx,感觉是最靠谱的方法。
而且现在大多数能兼容 WSGI 的框架我也都塞进 tornado 利用这个方案来跑,比如 flask 什么的。
cabinw
2011-08-30 16:15:51 +08:00
Tornado,向往已久的项目,没机会做
bhuztez
2011-08-30 16:19:41 +08:00
@istef 你觉得 tornado 相比 uwsgi 有啥优势
mywaiting
2011-08-30 16:28:58 +08:00
@Livid 求新项目地址围观。另外,弱弱问下Livid有开发V2EX的Roadmap么?不是说打算全部重写么?求解答。
Livid
2011-08-30 16:30:40 +08:00
@mywaiting 新项目 10 月上线。

PB2 我从来没有说过要全部重写。
mywaiting
2011-08-30 16:35:07 +08:00
@Livid 嗯嗯,收到。3Q:)
tioover
2011-08-30 16:40:35 +08:00
乱入下,那么大家的文件夹结构是啥样的?
istef
2011-08-31 10:56:16 +08:00
@bhuztez 其实比 uwsgi 应该没什么优势,而且我也没详细的做性能测试。只是服务器上已经配置了其它 tornado 应用,所以不想再折腾其它方案了。这样统一管理和维护起来简单的多。
dongying
2012-06-12 17:50:38 +08:00
如果以wsgi模式运行tornado,就失去了其最大的优势——异步非阻塞。wsgi不支持非阻塞请求

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

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

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

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

© 2021 V2EX