Tornado应用笔记01-简介

索引

  • => 01-简介
  • 02-Web框架
  • 03-协程与异步示例
  • 04-浅析源码
  • 05-异步客户端
  • 06-WebSocket与长轮询

笔者因为工作的原因接触到Tornado(/tɔrˈneɪdoʊ/, 龙卷风), 在学习的过程中参考不少文章, 虽然其中不乏优秀的文章, 但是内容大都是碎片化的, 缺少系统性, 而且不少关于异步应用的内容还是基于过时的旧版本. 因此打算将学习和开发过程中的记录整理成笔记, 即为了方便自己日后查阅, 也希望能够帮助到和我一样的Tornado的学习者, 于是就有了这个Tornado应用笔记. (注: 文章的代码都是基于Tornado 4.4+Python 2.7的, 不过只要你的版本不是特别老旧, 都是可以正常运行的. 另外, 文章并不是为初学者准备的, 阅读前要需要确认你已经了解Python语法, HTTP协议等Web开发所需的基础知识)

在Python Web框架中, 最为人熟知的三个是Django, FlaskTornado, 前两者是一重一轻的同步框架, 而后者则是以高性能著称的异步框架. 在使用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框架

你可能感兴趣的:(Tornado应用笔记01-简介)