tornado基础:hellotornado | tornado |《python学习之路》| python 技术论坛-金年会app官方网

未匹配的标注

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问题,这样的设计使得其成为一个拥有非常高性能的金年会app官方网的解决方案(服务器与框架的集合体)。

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

本文章首发在 金年会app官方网 网站上。

上一篇 下一篇
讨论数量: 0



暂无话题~
网站地图