Tornado 初识

2022-07-04 20:07:24 浏览数 (1)

作者 | 无量测试之道 编辑 | 小 晴
这是无量测试之道的第154篇原创
一、什么是tornado

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

二、tornado有什么优势

Tornado 和现在的主流baidu Web 服务器框架(包括大多数Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快,得利于其非阻塞的方式和对epoll的运用,Tornado 每秒可以处理数以千计的连接,因此Tornado 是实时Web 服务的一个理想框架。

三、tornado入门示例
代码语言:javascript复制
 1from tornado.web import Application #导入组成Web应用程序的请求处理程序的集合Application类,此实例化可以传递给httpserver以服务于应用程序
 2from tornado.web import RequestHandler #导入HTTP请求处理程序的基类RequestHandler
 3from tornado.ioloop import IOLoop #导入IOloop类,它是tornado web server 最底层的实现
 4from tornado.httpserver import HTTPServer #导入tornado的HTTP服务器,类似于tomcat,apache这样的web服务器
 5
 6class IndexHandler(RequestHandler):
 7    def get(self): # 重写get方法
 8        self.write('<h1>this is a get method</h1>') # 向客户端响应消息
 9    def post(self, *args, **kwargs):
10        self.write('<h1>this is a post method</h1>') # 向客户端响应消息
11
12if __name__ == '__main__': # 程序入口
13    app = Application(handlers=[
14        (r'/', IndexHandler), # 根据视图处理类handlers构建一个web application和定义路由访问规则表
15        ],debug=True) #打开debug调试
16    httpServer = HTTPServer(app) #创建了一个httpserver实例
17    httpServer.listen(8000) # 将服务器绑定到8000端口
18    httpServer.start(num_processes=1)#指定开启几个进程
19    IOLoop.current().start() # 启用tornado内置服务器事件轮询监听

服务启动后:

在浏览器里面输入:http://localhost:8000/

页面响应结果为:this is a get method。

四、debug=true 的妙用

debug 为True的特性:

  • 取消缓存编译的模板 compiled_template_cache = False
  • 取消缓存静态文件的hash值 static_hash_cache = False
  • 提供追踪信息 serve_traceback = True
  • 自动重启 autoreload=True

作用说明:

DEBUG设置为true时,工作在调试模式 调试模式中,保存改动时会重启服务器,减小手动重启服务器的次数 如果保存后的代码有错,会重启失败

具体的内容说明如下:

autoreload:这个参数的意思是当源代码(.py文件)改变的时候,服务器进程将自动重启。

compiled_template_cache:当这个参数是False时,每一次浏览器向服务器发出请求时,服务器下的模板都将重新编译。

static_hash_cache:当这个参数是False时,代码中使用了static_url()函数的地方都将被重新计算,因为每次调用static_url函数时它都创建了一个基于文件内容的hash值,并将其添加到URL末尾(查询字符串的参数v)。这个hash值确保浏览器总是加载一个文件的最新版而不是之前的缓存版本。

意思就是说如果你的static文件内容改变的话,那么产生的hash值也将改变,浏览器将会发现这样的变化,从而重新载入需要读取的static下的文件,而不是用自己已经缓存了的文件。

serve_traceback:traceback是Python 的处理异常栈的模块,我们在写Python 代码的时候,如果出错的了话,可以看到爆出一大堆错误,例如错误中可以追溯到错误地调用Python标准库的一些函数,我们在开发网站的时候如果遇到错误,一般浏览器只会返回404 not found, 505等错误信息,而代码的错误将在服务器终端显示出来,当这个serve_traceback被设置为True之后,我们就可以发现代码的错误也在浏览器上显示出来了。

0 人点赞