安装方式
自动安装
1、查看自己当前的环境是否已安装
$ pip list
2、安装
$ pip install tornado
手动安装
下载安装包tornado-4.3.tar.gz(https://pypi.python.org/packages/source/t/tornado/tornado-4.3.tar.gz)
$ tar xvzf tornado-4.3.tar.gz
$ cd tornado-4.3
$ python setup.py build
$ sudo python setup.py install
关于使用平台的说明
Tornado
应该运行在类Unix
平台,在线上部署时为了最佳的性能和扩展性,仅推荐Linux
和BSD
(因为充分利用Linux
的epoll
工具和BSD
的kqueue
工具,是Tornado
不依靠多进程/多线程而达到高性能的原因)。
对于Mac OS X
,虽然也是衍生自BSD
并且支持kqueue
,但是其网络性能通常不太给力,因此仅推荐用于开发。
对于Windows
,Tornado
官方没有提供配置支持,但是也可以运行起来,不过仅推荐在开发中使用。
示例代码
新建文件hello.py
,代码如下:
# coding:utf-8
import tornado.web
import tornado.ioloop
class IndexHandler(tornado.web.RequestHandler):
"""主路由处理类"""
def get(self):
"""对应http的get请求方式"""
self.write("Hello Itcast!")
if __name__ == "__main__":
app = tornado.web.Application([
(r"/", IndexHandler),
])
app.listen(8000)
tornado.ioloop.IOLoop.current().start()
执行如下命令,开启tornado
:
$ python hello.py
打开浏览器,输入网址127.0.0.1:8000
(或localhost:8000
),查看效果:
代码讲解
1. tornado.web
tornado
的基础web
框架模块
RequestHandler
封装了对应一个请求的所有信息和方法,write
(响应信息)就是写响应信息的一个方法;对应每一种http
请求方式(get、post
等),把对应的处理逻辑写进同名的成员方法中(如对应get
请求方式,就将对应的处理逻辑写在get()
方法中),当没有对应请求方式的成员方法时,会返回“405: Method Not Allowed
”错误。我们将代码中定义的get()
方法更改为post()
后,再用浏览器重新访问(浏览器地址栏中输入网址访问的方式为get
请求方式),演示如下:
# coding:utf-8
import tornado.web
import tornado.ioloop
class IndexHandler(tornado.web.RequestHandler):
"""主路由处理类"""
def post(self): # 我们修改了这里
"""对应http的post请求方式"""
self.write("Hello Itcast!")
if __name__ == "__main__":
app = tornado.web.Application([
(r"/", IndexHandler),
])
app.listen(8000)
tornado.ioloop.IOLoop.current().start()
ApplicationTornado Web
框架的核心应用类,是与服务器对接的接口,里面保存了路由信息表,其初始化接收的第一个参数就是一个路由信息映射元组的列表;其listen
(端口)方法用来创建一个http
服务器实例,并绑定到给定端口(注意:此时服务器并未开启监听)。
2. tornado.ioloop
tornado
的核心io
循环模块,封装了Linux
的epoll
和BSD
的kqueue
,tornado
高性能的基石。 以Linux
的epoll
为例,其原理如下图:
IOLoop.current()
:返回当前线程的IOLoop
实例。IOLoop.start()
:启动IOLoop
实例的I/O
循环,同时服务器监听被打开。