Tornado基础:HelloTornado

未匹配的标注

title: “Python 学习之路 - Tornado 基础:HelloTornado”
date: 2020-12-05
lastmod: 2020-12-06
draft: false
tags: [“Python 学习之路”]
categories: [“Tornado”]

summary: “”#

前言#

回想 Django 的部署方式#

以 Django 为代表的 python web 应用部署时采用 wsgi 协议与服务器对接(被服务器托管),而这类服务器通常都是基于多线程的,也就是说每一个网络请求服务器都会有一个对应的线程来用 web 应用(如 Django)进行处理

考虑两类应用场景#

  • 用户量大,高并发

如秒杀抢购、双十一某宝购物、春节抢火车票

  • 大量的 HTTP 持久连接

使用同一个 TCP 连接来发送和接收多个 HTTP 请求 / 应答,而不是为每一个新的请求 / 应答打开新的连接的方法。

对于 HTTP 1.0,可以在请求的包头(Header)中添加 Connection: Keep-Alive

对于 HTTP 1.1,所有的连接默认都是持久连接。

对于这两种场景,通常基于多线程的服务器很难应对。

C10K 问题#

对于前文提出的这种高并发问题,我们通常用 C10K 这一概念来描述。C10K—— Concurrently handling ten thousand connections,即并发 10000 个连接。对于单台服务器而言,根本无法承担,而采用多台服务器分布式又意味着高昂的成本。如何解决 C10K 问题?

Tornado#

Tornado 在设计之初就考虑到了性能因素,旨在解决 C10K 问题,这样的设计使得其成为一个拥有非常高性能的解决方案(服务器与框架的集合体)。

Tornado 是为何物#

简介#

Tornado 全称 Tornado Web Server,是一个用 Python 语言写成的 Web 服务器兼 Web 应用框架,由 FriendFeed 公司在自己的网站 FriendFeed 中使用,被 Facebook 收购以后框架在 2009 年 9 月以开源软件形式开放给大众。

特点#

  • 作为 Web 框架,是一个轻量级的 Web 框架,类似于另一个 Python web 框架 Web.py,其拥有异步非阻塞 IO 的处理方式。
  • 作为 Web 服务器,Tornado 有较为出色的抗负载能力,官方用 nginx 反向代理的方式部署 Tornado 和其它 Python web 应用框架进行对比,结果最大浏览量超过第二名近 40%。

性能#

Tornado 有着优异的性能。它试图解决 C10k 问题,即处理大于或等于一万的并发。Tornado 框架和服务器一起组成一个 WSGI 的全栈替代品。单独在 WSGI 容器中使用 tornado 网络框架或者 tornaod http 服务器,有一定的局限性,为了最大化的利用 tornado 的性能,推荐同时使用 tornaod 的网络框架和 HTTP 服务器

与 Django 对比#

Django#

Django 是走大而全的方向,注重的是高效开发,它最出名的是其全自动化的管理后台:只需要使用起 ORM,做简单的对象定义,它就能自动生成数据库结构、以及全功能的管理后台。

Django 提供的方便,也意味着 Django 内置的 ORM 跟框架内的其他模块耦合程度高,应用程序必须使用 Django 内置的 ORM,否则就不能享受到框架内提供的种种基于其 ORM 的便利。

  • session 功能
  • 后台管理
  • ORM

Tornado#

Tornado 走的是少而精的方向,注重的是性能优越,它最出名的是异步非阻塞的设计方式。

  • HTTP 服务器
  • 异步编程
  • WebSockets

本文章首发在 LearnKu.com 网站上。

上一篇 下一篇
讨论数量: 0
发起讨论 查看所有版本


暂无话题~