索引
笔者因为工作的原因接触到Tornado(/tɔrˈneɪdoʊ/, 龙卷风), 在学习的过程中参考不少文章, 虽然其中不乏优秀的文章, 但是内容大都是碎片化的, 缺少系统性, 而且不少关于异步应用的内容还是基于过时的旧版本. 因此打算将学习和开发过程中的记录整理成笔记, 即为了方便自己日后查阅, 也希望能够帮助到和我一样的Tornado的学习者, 于是就有了这个Tornado应用笔记. (注: 文章的代码都是基于Tornado 4.4+
和Python 2.7
的, 不过只要你的版本不是特别老旧, 都是可以正常运行的. 另外, 文章并不是为初学者准备的, 阅读前要需要确认你已经了解Python语法, HTTP协议等Web开发所需的基础知识)
在Python Web框架中, 最为人熟知的三个是Django, Flask和Tornado, 前两者是一重一轻的同步框架, 而后者则是以高性能著称的异步框架. 在使用Tornado的开发团队中, Quara和知乎是最常被提起的(参考: How-does-Quora-use-Tornado 和 知乎使用了哪些框架和开源库?).
我想在正文开始之前, 需要说明的是, 请不要迷信框架所谓的"高性能", 框架的作用是让开发者更快速和便捷的构建起所需的应用, 而性能则是由包括系统架构和开发人员能力在内的诸多因素决定的. 况且, 在高性能服务器价格相较开发人员的薪资"不值一提"和"面向上线时间编程"的今天, 过度追求高性能, 恐怕只会弊大于利. 倘若你将Tornado作为一个同步框架使用, 并认为框架能够"自主"实现高性能的话, 那我可真是无FUCK说了. 说到这里又不得不提Instagram 在 PyCon 2017 的演讲摘要, 其中分享了Instagram用一个以"慢"著称的Django构建一个支撑着7亿月活跃用户应用的故事.
首先来看Tornado的介绍(译自官方文档, 有删减):
Tornado是一个Python Web框架兼异步网络库, 最初由FriendFeed开发. 得益于非阻塞网络I/O, Tornado可以支撑起数以万计的连接, 因此它很非常适合开发长轮询, WebSockets和那些需要与每个用户建立持久连接的应用.
Tornado包含以下四大模块:
- Web框架
- HTTP服务器和客户端
- 异步网络库
- 协程库
Tornado的Hello World.
# -*- coding: utf-8 -*-
# file: hello.py
import tornado.ioloop
import tornado.web
# 定义一个路由类, 只能处理get请求, 请求返回"Hello Tornado!"
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.write("Hello Tornado!")
# 创建一个app, 并注册路由
def make_app():
return tornado.web.Application([
(r"/", MainHandler),
])
if __name__ == "__main__":
# 获取版本信息, 最好还是4.2及以上的版本
print 'Tornado version is <%s>' % tornado.version
app = make_app()
# 监听本地8888端口
app.listen(8888)
print 'Tornado server is running at localhost:8888'
# 暂时不需要关心下面语句的细节, 只需要知道其作用就是启动服务
tornado.ioloop.IOLoop.current().start()
运行以后, 在浏览器访问localhost:8888
, 就能看到Hello Tornado!
是的, 这个简单的示例并没有用到任何异步功能, 就是一个最基础的阻塞应用.
本节内容就是这些, 下节内容将分析Web框架中常用的套路.
NEXT ===> Tornado应用笔记02-Web框架