tornado基础:hellotornado | tornado |《python学习之路》| python 技术论坛-380玩彩网官网入口
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问题,这样的设计使得其成为一个拥有非常高性能的380玩彩网官网入口的解决方案(服务器与框架的集合体)。
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