Tornado应用笔记01-简介
2017-06-09 22:25
357 查看
笔者因为工作的原因接触到Tornado(/tɔrˈneɪdoʊ/, 龙卷风), 在学习的过程中参考不少文章, 虽然其中不乏优秀的文章, 但是内容大都是碎片化的, 缺少系统性, 而且不少关于异步应用的内容还是基于过时的旧版本. 因此打算写一个Tornado应用笔记的系列文章, 即为了方便自己日后查阅, 也希望能够帮助到和我一样的Tornado的学习者. (注: 文章的代码都是基于
在Python Web框架中, 最为人熟知的三个是Django, Flask和Tornado, 前两者是一重一轻的同步框架, 而后者则是以高性能著称的异步框架. 在使用Tornado的开发团队中, Quara和知乎是最常被提起的(参考: How-does-Quora-use-Tornado 和 知乎使用了哪些框架和开源库?).
我想在正文开始之前, 需要说明的是, 请不要迷信框架所谓的”高性能”, 框架的作用是让开发者更快速和便捷的构建起所需的应用, 而性能则是由包括系统架构和开发人员能力在内的诸多因素决定的. 况且, 在高性能服务器价格相较开发人员的薪资”不值一提”和”面向上线时间编程”的今天, 过度追求高性能, 恐怕只会弊大于利. 倘若你将Tornado作为一个同步框架使用, 并认为框架能够”自主”实现高性能的话, 那我可真是无FUCK说了. 说到这里又不得不提Instagram 在 PyCon 2017 的演讲摘要, 其中分享了Instagram用一个以”慢”著称的Django构建一个支撑着7亿月活跃用户应用的故事.
首先来看Tornado的简介:
Tornado is a Python web framework and asynchronous networking library, originally developed at FriendFeed. By using non-blocking network I/O, Tornado can scale to tens of thousands of open connections, making it ideal for long polling, WebSockets, and other applications that require a long-lived connection to each user.
Tornado是一个Python Web框架兼异步网络库, 最初由FriendFeed开发. 得益于非阻塞网络I/O, Tornado可以支撑起数以万计的连接, 因此它很非常适合开发长轮询, WebSockets和那些需要与每个用户建立持久连接的应用.
从简介可以看出Tornado并没强调自己Web框架的身份, 而是把重点放在建立长连接的特性上, 下面接着来看Tornado的Hello World.
运行以后, 在浏览器访问
本节内容就是这些, 下节将在
Tornado 4.4+&
Python 2.7的, 只要你的版本不是特别老旧, 都是可以正常运行的, 在下面的
Hello World中有提及查看版本的方法)
在Python Web框架中, 最为人熟知的三个是Django, Flask和Tornado, 前两者是一重一轻的同步框架, 而后者则是以高性能著称的异步框架. 在使用Tornado的开发团队中, Quara和知乎是最常被提起的(参考: How-does-Quora-use-Tornado 和 知乎使用了哪些框架和开源库?).
我想在正文开始之前, 需要说明的是, 请不要迷信框架所谓的”高性能”, 框架的作用是让开发者更快速和便捷的构建起所需的应用, 而性能则是由包括系统架构和开发人员能力在内的诸多因素决定的. 况且, 在高性能服务器价格相较开发人员的薪资”不值一提”和”面向上线时间编程”的今天, 过度追求高性能, 恐怕只会弊大于利. 倘若你将Tornado作为一个同步框架使用, 并认为框架能够”自主”实现高性能的话, 那我可真是无FUCK说了. 说到这里又不得不提Instagram 在 PyCon 2017 的演讲摘要, 其中分享了Instagram用一个以”慢”著称的Django构建一个支撑着7亿月活跃用户应用的故事.
首先来看Tornado的简介:
Tornado is a Python web framework and asynchronous networking library, originally developed at FriendFeed. By using non-blocking network I/O, Tornado can scale to tens of thousands of open connections, making it ideal for long polling, WebSockets, and other applications that require a long-lived connection to each user.
Tornado是一个Python Web框架兼异步网络库, 最初由FriendFeed开发. 得益于非阻塞网络I/O, Tornado可以支撑起数以万计的连接, 因此它很非常适合开发长轮询, WebSockets和那些需要与每个用户建立持久连接的应用.
从简介可以看出Tornado并没强调自己Web框架的身份, 而是把重点放在建立长连接的特性上, 下面接着来看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!是的, 这个简单的示例并没有用到任何异步功能, 就是一个最基础的阻塞应用.
本节内容就是这些, 下节将在
Hello World的基础上进行扩展, 介绍Tornado的路由类
tornado.web.RequestHandler中的常用方法.
相关文章推荐
- 02 安卓现状以及应用领域简介(从01开始点点入门,视频+笔记)
- Tornado 的 IOStream 简介与应用
- 《Web编程入门经典》学习笔记 - Lesson01:创建结构化文档:XHTML简介、核心元素、属性组与基本文本格式
- Tornado 的 IOStream 简介与应用
- c笔记01---扩展名简介,linux 常用命令,vi 设置
- 大数据笔记01:大数据之Hadoop简介
- 《asp.net 2.0应用开发技术》 笔记 01
- (原创)c#学习笔记08--面向对象编程简介01--面向对象编程的含义01--对象的含义01--属性和字段
- sql_学习笔记01_简介
- 【Android 应用开发】Android 网络编程 API笔记 - java.net 包 权限 地址 套接字 相关类 简介
- javaEE学习笔记【01】集成环境开发应用、JDK新特性
- 01_Struts与JavaWeb应用简介
- Objective-c学习笔记01——简介
- 01、XML简介及企业中的应用
- Replica Island 学习笔记 01 - 简介
- UML笔记01-UML的简介
- jQuery EasyUI学习笔记_1.easyui简介和简单应用
- Objective-c学习笔记01——简介
- Spark调研笔记第3篇 - Spark集群对应用的调度策略简介
- tornado 学习笔记5 构建Tornado网站应用