Tornado是使用Python编写的一个强大的、可扩展的Web服务器。它在处理严峻的网络流量时表现得足够强健,但却在创建和编写时有着足够的轻量级,并能够被用在大量的应用和工具中。

首先是安装tornado. tornado不支持windows。如果需要在windows下安装可以通过ActivePython的PyPM包管理器进行安装类似:pypm install tornado

在linux下安装就简单多了。pip install tornado就可以了

下面我们进入tornado的功能。首先来看一个基本的web应用,在给定的端口上监听请求,并在根目录”/”响应请求

import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web from tornado.options import define,options
define("port",default=8000,help="run on the given port",type=int) class indexHandler(tornado.web.RequestHandler):
def get(self, *args, **kwargs):
greeting=self.get_argument('greeting','hello')
self.write(greeting+'tornado user') def server_function():
tornado.options.parse_command_line()
app = tornado.web.Application(handlers=[(r"/", indexHandler),(r"/index",indexHandler)])
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port,address='127.0.0.1')
tornado.ioloop.IOLoop.instance().start()

在终端执行:

zhf@zhf-maple:~/py_prj$ python tornada_try.py

然后在浏览器输入http://localhost:8000/

此时在终端上可以看到对应的输出。

zhf@zhf-maple:~/py_prj$ python tornada_try.py

[I 171204 10:53:23 web:2063] 200 GET / (127.0.0.1) 0.49ms

[W 171204 10:53:23 web:2063] 404 GET /favicon.ico (127.0.0.1) 0.40ms

下面来介绍下上面应用的各个模块:

首先看下options功能。在运行代码的时候会设置端口和地址等参数。python自带有argparse模块进行参数解析。tornado中不需要调用argparse模块而是自带了options模块。下面是测试代码:

import tornado.options

from tornado.options import options

if __name__=="__main__":
    tornado.options.parse_command_line()
    print options.port

终端执行脚本:

zhf@zhf-maple:~/py_prj$ python tornada_try.py --port=8001

8001

如果加入了不存在的参数会报如下的错误

zhf@zhf-maple:~/py_prj$ python tornada_try.py --addr=127.0.0.1

tornado.options.Error: Unrecognized command line option: 'addr

也可以不带参数,通过define来设置默认参数。如下。port代表新增加的参数名称

default代表默认值,help代表帮助信息,当使用--help的时候会打印help的字段。type代表了前面新加参数的类型。

from tornado.options import define

define("port",default=9000,help="run on the given port",type=int)

from tornado.options import define

define("port",default=9000,help="run on the given port",type=int)

运行结果如下:

zhf@zhf-maple:~/py_prj$ python tornada_try.py

9000

zhf@zhf-maple:~/py_prj$ python tornada_try.py --help

tornada_try.py options:

--port                           run on the given port (default 9000)

IndexHandler:这个类继承于tornado.web.RequestHandler。每当网页发起一个请求的时候,Tornadah会调用这个类并将其实例化。然后调用HTTP请求所对应的方法。也就是get方法,这个处理函数将对HTTP的GET请求作出响应。

在get方法中调用了get_argument方法。这个函数的作用是增加参数greeting,并初始化为hello。在后面的write方法调用。

write方法:这个参数的作用是生成HTTP response的具体信息。在这里里面的参数是greeting+“tornado user”, 因此在网页中生成的信息是hellotornado user

Application: 这是tornado运转起来的语句,tornado.web.Application(handlers=[(r"/", IndexHandler)])创建了一个Application实例,传递给Application的__init__函数最重要的是参数是handler,也就是[(r"/", IndexHandler)]。 handler告诉tornado该 用哪个类来响应请求。

最后是服务器的启动:listen方法监听端口和地址。ioloop方法循环执行server监听功能。

http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port,address='127.0.0.1')
tornado.ioloop.IOLoop.instance().start()

我们来具体看下handler参数的用法。这个handler参数是一元组组成的列表。其中元组第一个参数代表的是网页访问路径,第二个是该访问路径的触发实例

tornado.web.Application(handlers=[(r"/", indexHandler)]}

在前面的运行中,在网页中输入http://localhost:8000/可以得到打印的字符串。但是如果我们输入http://localhost:8000/index则会提示404:Not Found.提示找不到对应的网页。原因在于我们在handlers中并没有添加/index的处理方法。这就相当与django中的路由机制:


url(r'index/',views.index)      /index对应的处理函数是views.index

那么如果我们要访问index这个网页路径,也需要在handers中添加对应的路由机制。这样当输入http://localhost:8000/index 也会调用indexHandler实例

tornado.web.Application(handlers=[(r"/", indexHandler),(r"/index",indexHandler)]

另外在indexHandler中我们只定义了get方法。在网页中传递数据有get和post两种方法。如果网页采用的是post的方法,那么同样的在indexHandler中需要定义post函数,用法和get函数是一样的。

 
												

tornado之运行第一个tornado程序的更多相关文章

  1. 运行第一个Hadoop程序,WordCount

    系统: Ubuntu14.04 Hadoop版本: 2.7.2 参照http://www.cnblogs.com/taichu/p/5264185.html中的分享,来学习运行第一个hadoop程序. ...

  2. Spark认识&环境搭建&运行第一个Spark程序

    摘要:Spark作为新一代大数据计算引擎,因为内存计算的特性,具有比hadoop更快的计算速度.这里总结下对Spark的认识.虚拟机Spark安装.Spark开发环境搭建及编写第一个scala程序.运 ...

  3. 运行第一个ruby程序

    0x00 安装 首先需要安装一个ruby的环境,ruby分为win.linux.macOS版本.不用系统安装方法略有差异,不在这进行讲解. 0x01 运行第一个ruby程序 我这里是win环境,打开命 ...

  4. 运行第一个python程序,python 变量,常量,注释

    一.运行第一个python程序: print('Hello,world') 保存为.py文件 在cmd窗口: python3x:python  py文件路径 回车 python2x:python  p ...

  5. OpenCV学习笔记(一)安装及运行第一个OpenCV程序

    1.下载及安装 OpenCV是一套开源免费的图形库,主要有C/C++语言编写,官网: http://opencv.org/ .在 http://opencv.org/downloads.html 可以 ...

  6. 运行第一个Python程序

    Python的三种运行方式 交互式解释器 在终端输入python3 进入python交互式解释器 输入exit()退出交互式解释器 命令行脚本 创建python脚本 通过命令执行程序 python h ...

  7. 使用Eclipse运行第一个Go程序

    Windows 10家庭中文版,go version go1.11 windows/amd64, Eclipse IDE for C/C++ Developers Photon Release (4. ...

  8. [IOS]从零开始搭建基于Xcode7的IOS开发环境和免开发者帐号真机调试运行第一个IOS程序HelloWorld

    首先这篇文章比较长,若想了解Xcode7的免开发者帐号真机调试运行IOS程序的话,直接转到第五部分. 转载请注明原文地址:http://www.cnblogs.com/litou/p/4843772. ...

  9. 编译运行第一个Java程序——通过示例学习Java编程3

    作者:CHAITANYA SINGH 来源:https://www.koofun.com//pro/kfpostsdetail?kfpostsid=13 在本教程中,我们将了解如何编写.编译和运行Ja ...

随机推荐

  1. IPC 通信接口函数的名字

      IPC三种通信机制是指:信号量.共享内存.消息队列 ,管道和命名管道,socket套接字    信号量:通过操作系统中的PV操作来实现: 共享内存:申请一块内存,进程A往共享内存中写,其他的进程就 ...

  2. Servlet 2.4 规范之第五篇:请求

    request对象封装了来自客户端的所有请求信息.在HTTP协议中,客户端发给服务端的所有信息都是通过request对象的请求头和请求体来传送的.           SRV.4.1    HTTP协 ...

  3. fetch格式

    fetch('url'+参数a, { method: "GET", body: json } .then(res => response.json()) .then(cons ...

  4. Android内存泄漏总结

    内存泄漏问题老生常谈,很常见也很难根治,今天我在这里总结一下内存泄漏的原因和解决方法: 所谓内存泄漏,就是本该被回收的对象,由于某些原因不能被回收,继续占用堆内存的这种状态,导致的结果也是显而易见的, ...

  5. 阿里数据库性能诊断的利器——SQL执行干预

    概述 在业务数据库性能问题诊断中,如果发现一个业务性能很差跟某个SQL有关,应用连接池几乎被该SQL占满,同时数据库服务器上也不堪重负.此时情况很紧急,业务改SQL重发布已经来不及了,运维能选择的操作 ...

  6. Tyvj——P1864 [Poetize I]守卫者的挑战

    来源:http://www.tyvj.cn/p/1864 描述 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过.“我,Niz ...

  7. java单例模式教程之java实现单例模式的8大方法

    单例模式是Java中常用的设计模式之一.单例模式属于创建型模式,它提供了一种创建对象的最佳方式. 单例模式只创建类的一个对象,之后在一定范围为可任意调用,确保只有单个对象被创建.这个类提供了一种访问其 ...

  8. MyBatis的一级缓存和二级缓存

    一级缓存 是SqlSession级别的缓存,当使用了clearCache方法和,或者close方法的话,这个缓存失效,如果还有同样的查询,则还会发送一次查询 SqlSession session = ...

  9. 动态加载/删除css文件以及图片预加载

    动态加载/删除css文件以及图片预加载   功能模块页面   最近,工作中遇到了一个比较奇葩的需求:要在一个页面(PC端)增加一个功能模块,但是这个页面在不久之后要重构,为了新增加的模块可以继续复用, ...

  10. DozerBeanMapper + 对象转Map方法

    1.简介     dozer是一种JavaBean的映射工具,类似于apache的BeanUtils.但是dozer更强大,它可以灵活的处理复杂类型之间的映射.不但可以进行简单的属性映射.复杂的类型映 ...