一:tornado是什么?
- tornado是一个兼web框架以及服务器的framework。既能进行web application的开发,同时也内置了高性能的web服务器。---ps常规操作情况下tornado开发的应用程序,最好部署在tornado自己的http服务器中,以便发挥它最好的处理性能。
- tornado是一个免费的、开源的、高性能、高并发、基于epoll/kqueue内核处理机制的一个用于快速高效开发web application的web框架兼服务器!
二:tornado的特点!
1.高并发高性能:同时有多个连接访问服务器的情况
- Tornado默认情况下,是单进程单线程操作方式,即使是在多进程工作模式下,每个进程也只有一个线程在工作,是通过调用OS(opration systement)底层的事件轮训调度处理方式实现的高并发操作
注意:windows下并不能发挥tornado的优势,tornado程序在开发时可以在windows的开发工具下进行开发,但是项目部署一定要部署在like linux/like BSD内核的操作系统中,底层的高并发就是调用了like linux epoll以及like BSD kqueue内核进行的高并发处理。
2.异步非阻塞IO
3.websocket长连接
3.内置高性能HTTP服务器
三:tornado程序以及核心API介绍!
- 安装需要的模块
安装tornado模块
----->pip install tornado
- 开发步骤
1.引入需要的模块
----->from tornado.web import Application,RequestHandler
----->from tornado.ioloop import IOLoop
关键字解释:
Handler:句柄,处理,操作的意思;
RequestHandler:请求处理对象;
Loop:循环的意思;
IOLoop:输入输出循环,非阻塞状态的IO轮询!注意:tornado.web.RequestHandler:tornado web框架核心的一个处理类,主要进行用户请求对象的处理,用户发送的各种请求方式都包含在RequestHandler中进行操作,在实际开发的过程中,我们自定义的处理类要继承这个类,重写它的各种请求处理方式,方便在程序运行过程中可以处理对应的客户端url请求。
tornado.ioloop.IOLoop:tornado web服务器的核心处理类,主要进行用户请求的轮询的遍历操作,针对客户端发起的多请求。进行轮询操作。
2.开发视图处理类:就是一个普通的类型,继承tornado.web.RequestHandler,为处理不同的请求方式,需要重写父类中的请求处理方式。
---->class IndexHandler(RequestHandler):
-------->def get(self):#重写父类get请求方法
------------>self.write()#通过self.write()可以直接向客户端响应数据
3.构建web应用程序-------启动服务器
-------->app = Application([ (r'/',IndexHandler), ])#构建web application程序
-------->app.listen(8000)#监听8000端口
-------->IOLoop.current().start()#开始事件轮询
直接干货代码:第一个tornado程序
from tornado.web import Application,RequestHandler
from tornado.ioloop import IOLoop
class IndexHandler(RequestHandler):
def get(self):#重写get方法
self.write('hello word tornado') #向客户端响应一个数据
if __name__ == '__main__':#程序入口
app = Application([
(r'/', IndexHandler), #根据视图处理类构建一个web application和定义路由访问
])
app.listen(8008)#监听端口
IOLoop.current().start()#启用tornado内置服务器事件轮询监听
四:小结
- 了解tornado的定义和特点,简单基本程序的创建,开发出了一个简单的tornado完整的web程序
- 对于tornado核心的API(application program interface 应用程序开发接口,指代的就是软件中内置的各个对象或者函数)的介绍
- 底层高性能的原理介绍,通过IOLoop对象的调用like linux/likeBSD操作系统内核的epoll/kqueue实现的IO事件轮询处理机制