Tornado——入门基础(一)

2017-12-25  本文已影响0人  哈喽小生

一:tornado是什么?

二: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事件轮询处理机制

未完待续......

上一篇 下一篇

猜你喜欢

热点阅读