-------------------简介-------------------
1、概念:
    Tornado全称Tornado Web Server,是一个用Python语言写成的Web服务器兼Web应用框架,由FriendFeed公司在自己的网站FriendFeed中使用,被Facebook收购以后框架在2009年9月以开源软件形式开放给大众。
 
2、特点:
    1、作为Web框架,是一个轻量级的Web框架,类似于另一个Python web框架Web.py,其拥有异步非阻塞IO的处理方式。
 
    2、作为Web服务器,Tornado有较为出色的抗负载能力,官方用nginx反向代理的方式部署Tornado和其它Python web应用框架进行对比,结果最大浏览量超过第二名近40%。
 
3、性能:
    1、Tornado有着优异的性能。它试图解决C10k问题,即处理大于或等于一万的并发
 
    2、Tornado框架和服务器一起组成一个WSGI的全栈替代品。单独在WSGI容器中也可以使用
 
    3、tornado网络框架或者tornaod http服务器,有一定的局限性,为了最大化的利用
 
 
-------------------Tornado与Django的区别-------------------
1、Tornado
    1、Tornado走的是少而精的方向,注重的是性能优越,它最出名的是异步非阻塞的设计方式。
 
    2、特点:
        1、HTTP服务器:Tornado框架和服务器一起组成一个WSGI的全栈替代品
 
        2、异步编程
 
        3、WebSockets
 
2、Django
    1、Django是走大而全的方向,注重的是高效开发,它最出名的是其全自动化的管理后台:只需要使用起ORM,做简单的对象定义,它就能自动生成数据库结构、以及全功能的管理后台。
 
    2、Django提供的方便,也意味着Django内置的ORM跟框架内的其他模块耦合程度高,应用程序必须使用Django内置的ORM,否则就不能享受到框架内提供的种种基于其ORM的便利。
 
    3、特点:
        1、session功能
 
        2、后台管理
 
        3、ORM
 
 
-------------------Tornado安装
1、查看工作环境中是否安装
    $ pip list
 
2、安装对应的tornado环境
    1、自动安装
        $ pip install tornado
 
    2、手动安装
        1、下载安装包tornado-4.3.tar.gz(https://pypi.python.org/packages/source/t/tornado/tornado-4.3.tar.gz)
 
        2、$ tar xvzf tornado-4.3.tar.gz
 
        3、$ cd tornado-4.3
 
        4、$ python setup.py build
 
        5、$ sudo python setup.py install
 
3、安装对应的数据库操作环境
    $ pip install trondb
 
 
-------------------Tornado基本模块
1、Tornado web 程序编写思路
    1、创建web应用实例对象,第一个初始化参数为路由映射列表。
 
    2、定义实现路由映射列表中的handler类。
 
    3、创建服务器实例,绑定服务器端口。
 
    4、启动当前线程的IOLoop。
 
2、tornado.web
    1、RequestHandler:
        封装了对应一个请求的所有信息和方法,write(响应信息)就是写响应信息的一个方法;对应每一种http请求方式(get、post等),把对应的处理逻辑写进同名的成员方法中(如对应get请求方式,就将对应的处理逻辑写在get()方法中),当没有对应请求方式的成员方法时,会返回“405: Method Not Allowed”错误。
 
    2、Application:
        Tornado Web框架的核心应用类,是与服务器对接的接口,里面保存了路由信息表,其初始化接收的第一个参数就是一个路由信息映射元组的列表;其listen(端口)方法用来创建一个http服务器实例,并绑定到给定端口(注意:此时服务器并未开启监听)。
 
3、tornado.ioloop
    1、tornado的核心io循环模块,封装了Linux的epoll和BSD的kqueue,tornado高性能的基石
 
    2、Linux的epoll原理图
 
    3、IOLoop.current():
        返回当前线程的IOLoop实例。
 
    4、IOLoop.start():
        启动IOLoop实例的I/O循环,同时服务器监听被打开。
 
4、tornado.httpserver
    实例:
        #coding:utf-8
        #一个简单的Tornado web
 
        #引用对应的Tornado包
        from tornado.web import Application,RequestHandler
        from tornado.ioloop import IOLoop
        from tornado.httpserver import HTTPServer
 
        class IndexHandler(RequestHandler):
 
            def get(self):
 
                self.write('hello word!')
 
        if __name__ == '__main__':
            #创建一个app应用
            app = Application([('/',IndexHandler)])
 
            #app.listen('8000')
            #为应用创建一个http服务
            http_server = HTTPServer(app)
 
            #绑定对应的端口号
            http_server.listen(8000)
 
            #开启多个tornado进程
            #http_server.bind(8000)
            #http_server.start(4)
 
            IOLoop.current().start()
 
5、tornado.options
    1、tornado.options模块——全局参数定义、存储、转换。
 
    2、tornado.options.define()
        1、def define(name, default=None, type=None, help=None, metavar=None,
           multiple=False, group=None, callback=None):
 
        2、name 选项变量名,须保证全局唯一性,否则会报“Option 'xxx' already defined in ...”的错误;
 
        3、default 选项变量的默认值,如不传默认为None;
 
        4、type 选项变量的类型,从命令行或配置文件导入参数的时候tornado会根据这个类型转换输入的值,转换不成功时会报错,可以是str、float、int、datetime、timedelta中的某个,若未设置则根据default的值自动推断,若default也未设置,那么不再进行转换。可以通过利用设置type类型字段来过滤不正确的输入。
 
        5、multiple 选项变量的值是否可以为多个,布尔类型,默认值为False,如果multiple为True,那么设置选项变量时值与值之间用英文逗号分隔,而选项变量则是一个list列表(若默认值和输入均未设置,则为空列表[])。
 
        6、help 选项变量的帮助提示信息,在命令行启动tornado时,通过加入命令行参数 --help 可以查看所有选项变量的信息(注意,代码中需要加入tornado.options.parse_command_line())。
 
    3、tornado.options.options
        全局的options对象,所有定义的选项变量都会作为该对象的属性。
 
    4、tornado.options.parse_command_line()
        1、进行对应的初始化
 
    5、tornado.options.parse_config_file(path)
 
    6、实例
      #coding:utf-8
      #一个简单的Tornado web
 
      #引用对应的Tornado包
      from tornado.web import Application,RequestHandler
      from tornado.ioloop import IOLoop
      from tornado.httpserver import HTTPServer
      import tornado.options
 
 
      tornado.options.define("port",type=int,help="端口号")
 
      class IndexHandler(RequestHandler):
 
          def get(self):
 
              self.write('hello word!')
 
      if __name__ == '__main__':
          tornado.options.parse_command_line()
 
 
          #创建一个app应用
          app = Application([('/',IndexHandler)])
 
          #app.listen('8000')
          #为应用创建一个http服务
          http_server = HTTPServer(app)
 
          #绑定对应的端口号
          http_server.listen(tornado.options.options.port)
 
          #开启多个tornado进程
          #http_server.bind(8000)
          #http_server.start(4)
 
          IOLoop.current().start()

Tornado框架简介的更多相关文章

  1. python运维开发(二十二)---JSONP、瀑布流、组合搜索、多级评论、tornado框架简介

    内容目录: JSONP应用 瀑布流布局 组合搜索 多级评论 tornado框架简介 JSONP应用 由于浏览器存在同源策略机制,同源策略阻止从一个源加载的文档或脚本获取或设置另一个源加载的文档的属性. ...

  2. Tornado框架简介(二)

    --------------------Application-------------------- 1.settings     1.debug=True:,设置tornado是否工作在调试模式, ...

  3. Django框架简介,wsgiref 与 jinja2 模块

    目录 框架简介 wsgiref模块 jinja2 模块 框架简介 Django是一个web开发框架,用来开发web应用,本质就是, web框架+socket服务端 MVC框架和MTV框架 MVC,全名 ...

  4. wsgiref模块、web框架、django框架简介

    """web框架:将前端.数据库整合到一起的基于互联网传输的python代码 web框架也可以简单的理解为是软件开发架构里面的'服务端'""" ...

  5. 手动搭建简易web框架与django框架简介

    目录 纯手写简易web框架 基于wsgiref模块 动静态网页 简单了解jinja2模块 框架请求流程 python主流web框架 django框架 简介 应用app 命令操作django pycha ...

  6. Spring 系列: Spring 框架简介 -7个部分

    Spring 系列: Spring 框架简介 Spring AOP 和 IOC 容器入门 在这由三部分组成的介绍 Spring 框架的系列文章的第一期中,将开始学习如何用 Spring 技术构建轻量级 ...

  7. 《HiWind企业快速开发框架实战》(0)目录及框架简介

    <HiWind企业快速开发框架实战>(0)目录及框架简介 本系列主要介绍一款企业管理系统快速开发框架,该框架旨在快速完成企业管理系统,并实现易维护可移植的目标. 使用逐个系统模块进行编码的 ...

  8. Yaf零基础学习总结1-Yaf框架简介

    从今天开始,给大家讲解下yaf框架,讲解之前肯定要了解下yaf是个什么东西,当然,从标题我们已经知道yaf是个PHP框架了,也许大家对于PHP框架并不陌生,一般PHP程序员用过的框架至少有一两个吧,国 ...

  9. hdwiki 框架简介

    虽然HDwiki是一个开源的wiki系统,并且代码简洁易懂,但如果想在系统上做做进一步开发还需要对框架有一个整体的认识.熟悉了HDwiki的框架以后完全可以独立出来做其他功能的开发,当做一个开源的PH ...

随机推荐

  1. app耗电优化之四 使用AlarmManager对任务进行合理安排

    AlarmManager 是用来设定定时任务.即用来设定那个任务在什么时候开始执行.为什么和省电有关系?这个需要和AlarmManager的使用先说起.AlarmManager 实际上只起到一个定时发 ...

  2. ETL作业调度工具TASKCTL软件安装乱码问题解决

    前两天在安装批量作业调度软件TASKCTL4.5时,将安装介质解压出来后执行安装脚本时,一安装就出现下图乱码. 然后就度娘了一下,发现安装遇到乱码的人还挺多的,大多数解答都说TASKCTL软件里面很多 ...

  3. IBM Websphere 集群会话共享问题解决办法

    遇到一应用部署环境如下图: 两台HTTP SERVER(以下简称IHS)负责转发数据包,其中F5采用粘性模式,即一个用户在会话周期内的数据包一定会被转发到IHS中的一台, 但IHS 到Web Serv ...

  4. c++ STL 容器——序列

    STL中11个容器类型分别是deque,list,queue,priority_queue,stack,vector,map,multimap,set,multiset,bieset(在比特级处理数据 ...

  5. sysstat -6.0.2 lib not install

    执行oracle安装包./setup.sh 后跳出,无法执行数据库的安装,并提示类似下面 的错误信息-- ERROR:===wed Aug 15 08:43:23 CST 2012===sysstat ...

  6. Section 1.1 Greedy Gift Givers

    Greedy Gift Givers A group of NP (2 ≤ NP ≤ 10) uniquely named friends hasdecided to exchange gifts o ...

  7. C语言中全局变量存放在哪个位置?

    今年软考的时候,遇到了这个题目,表示不解,然后考完之后去查了一下百度,才发现自己选错.全局变量存放在静态存储区,位置是固定的. 局部变量在栈空间,栈地址是不固定的.栈:就是那些由编译器在需要的时候分配 ...

  8. mysql 中的socket 即 mysql.sock的作用

    这个mysql.sock应该是mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体,它比tcp快.通常遇到这个问题的原因就是你的mysql ser ...

  9. UNIX 技巧: UNIX 高手的另外 10 个习惯

    让我们面对现实吧:坏习惯很难改变.但是您已经熟悉的习惯可能更难克服.有时,重新审视某些事情可能让您遇到“啊哈,我没想到它能做到这一点!”的时刻.在 Michael Stutz 的优秀文章“UNIX 高 ...

  10. Mysql报错注入原理分析(count()、rand()、group by)

    Mysql报错注入原理分析(count().rand().group by) 0x00 疑问 一直在用mysql数据库报错注入方法,但为何会报错? 百度谷歌知乎了一番,发现大家都是把官网的结论发一下截 ...