一文读懂Python web框架和web服务器之间的关系
我们都知道 Python 作为一门强大的语言,能够适应快速原型和较大项目的制作,因此被广泛用于 web 应用程序的开发中。
在面试的过程中,大家或多或少都被问到过这样一个问题:一个请求从浏览器发出到数据返回都经历过哪些过程?
要回答这个问题,首先你需要对 HTTP 协议、web框架、服务器等底层知识有一定的储备量,同时需要对 web 框架和服务器之间的关联有一定的了解,这里有张图上面详细的标明它们之间的联系。

这么多 wsgi 是不是有点懵逼?看不明白没有关系,下面我会带大家顺着图片里面的顺序一步一步来搞懂里面的概念,厘清它们之间的关系
一、web 框架
在 Python 有很多 web 框架,其中常见的像 Django、Flask、Tornado 、sanic 等,可能有些人对 sanic 不是很熟悉,这里简单说几句,它的用法和 Flask 很相似,但是它支持 async/await 异步并发编程,所以相对来说性能更高。这里就不对这些框架作比较了,因为这不是我们今天的重点!
熟悉的朋友都知道 Web 框架包含一系列库和一个主要的处理器 (handler),这样你就能够构建自己的代码来实现 Web 应用 (比如说一个交互式的网站)。大多数 web 框架包含模式和工具,能实现以下功能:
URL 路由
将输入的 HTTP 请求匹配到特定的路由函数,通过路由函数来调用对应的 Python 代码
请求和响应对象
Python 中的大多的 web 框架都帮我们封装好了来自用户发送的 HTTP 请求 Request,同时也提供了发送给用户浏览器的 Response 对象
模板引擎
能够将实现应用的 Python 代码逻辑和其要产生输出的 HTML (或其他的) 分离开,例如比较知名的 Jinja2 模板引擎。它使用基于文本的模板语言,因此可以用来生成任何类型的标记,而不仅仅是 HTML。它允许定制过滤器、标签、测试和全局变量
Web 服务开发
除了上述之外,单单一个 web 框架并不能支撑我们应用上的服务,需要在开发机上运行 HTTP 服务器,从而快速开发;这就需要涉及到 web 框架和服务器之间的通信等问题。
好在 Python 给我们提供了这样的协议接口,也就是我们常说的 WSGI 协议!下面来了解一下什么是 WSGI 。
二、WSGI协议
Web 服务网关接口 (简称为 "WSGI") 是一种在 Web 服务器和 Python Web 应用程序框架之间的标准接口。通过标准化 Web 服务器和 Python web 应用程序框架之间的行为和通信,WSGI 使得编写可移植的的 Python web 代码变为可能,使其能够部署在任何符合 WSGI 的 web 服务。
有了 WSGI 协议,我们就不需要为每一个 web 框架去搞一套协议,因为基本上所有的Python web 框架都支持这个协议。
三、uWSGI服务器
uWSGI 服务器也就是图片中的所指的 WSGI 容器, 独立 uWSGI 服务器相比传统 web 服务器,使用更少的资源,并提供最高的性能 。Python 中的 uWSGI 服务器应用最广的主要包含以下几个:
Gunicorn
Gunicorn (Green Unicorn,绿色独角兽) 是一个纯 Python WSGI 服务器,用来支持 Python 应用。不像其他 Python web 服务器,它有周全的用户界面,十分易于使用和配置。
Gunicorn 具有合理的默认配置。然而,其他一些像 uWSGI 这样的服务器相较而言过于可定制化,因此更加难以高效使用。
Gunicorn 是如今新 Python web 应用程序的推荐选择。
Waitress
Waitress 是一个纯 Python WSGI 服务器,声称具备 “非常高效的性能”。它的文档不是很详细,但它确实提供了一些很好的而 Gunicorn 没有的功能(例如 HTTP 请求缓冲)。
Waitress 在 Python Web 开发社区中越来越受欢迎。
uWSGI
你没有看错,又是 uWSGI!uWSGI 用来构建全栈式的主机服务。除了进程管理、进程监控和其他功能外, uWSGI 也能作为一个应用服务器,适用于多种编程语言和协议 - 包括 Python 和 WSIG。uWSGI 既能当作独立的 web 路由器来运行,也能运行在一个完整 web 服务器(比如 Nginx 或 Apache )之后。对于后者,web 服务器可以基于 uwsgi 协议 配置 uWSGI 和应用的操作。uWSGI 的 web 服务器支持允许动态配置 Python 、传递环境变量等。
四、uwsgi 协议
uwsgi 协议:与 WSGI 一样是一种通信协议,它是 web 服务器 和 uWSGI 服务器之间的协议,一个 uWSGI 服务器的独占协议,它是用于定义传输信息的类型(type of information),每一个 uwsgi packet前4byte为传输信息类型的描述,与 WSGI协议 是两种东西。
五、Web 服务器端
Web 服务器包括 Nginx,Apache,IIS 等。而优秀的 web 服务器在接收 http 请求时,还可以做负载均衡和反向代理等工作。
Nginx
Nginx 是一个 web 服务器,并且是 HTTP 、SMTP 和其他协议的反向代理。它由其高性能、相对简洁以及对众多应用服务器 (比如 WSGI 服务器) 兼容而著名。
它也拥有便利的特性, 比如负载均衡、基本的认证、流等。Nginx 被设计为承载高负载的网站,并逐渐变得广为流行。所以我们一般用 Nginx来做还可以做负载均衡和反向代理!
当然除了厘清以上的概念及它们之间的关系之外,您还需要知道 HTTP 协议的知识,这部分也是在面试中经常被问到的,这里就不做赘述了。
请帮忙点赞
一文读懂Python web框架和web服务器之间的关系的更多相关文章
- VS2010/MFC编程入门之四十(文档、视图和框架:各对象之间的关系)
前面一节中鸡啄米进行了文档.视图和框架的概述,本节主要讲解文档.视图.框架结构中各对象之间的关系. 各个对象之间的关系 文档.视图.框架结构中涉及到的对象主要有:应用程序对象.文档模板对象.文档对象. ...
- VS2010-MFC(文档、视图和框架:各对象之间的关系)
转自:http://www.jizhuomi.com/software/223.html 前面一节进行了文档.视图和框架的概述,本节主要讲解文档.视图.框架结构中各对象之间的关系. 各个对象之间的关系 ...
- 转---一文读懂 python 的元类
译注:这是一篇在Stack overflow上很热的帖子.提问者自称已经掌握了有关Python OOP编程中的各种概念,但始终觉得元类(metaclass)难以理解.他知道这肯定和自省有关,但仍然觉得 ...
- pyi文件是干嘛的?(一文读懂Python的存根文件和类型检查)
参考资料: https://blog.csdn.net/weixin_40908748/article/details/106252884 https://www.python.org/dev/pep ...
- 一文读懂高性能网络编程中的I/O模型
1.前言 随着互联网的发展,面对海量用户高并发业务,传统的阻塞式的服务端架构模式已经无能为力.本文(和下篇<高性能网络编程(六):一文读懂高性能网络编程中的线程模型>)旨在为大家提供有用的 ...
- 一文读懂 深度强化学习算法 A3C (Actor-Critic Algorithm)
一文读懂 深度强化学习算法 A3C (Actor-Critic Algorithm) 2017-12-25 16:29:19 对于 A3C 算法感觉自己总是一知半解,现将其梳理一下,记录在此,也 ...
- 一文读懂clickhouse集群监控
更多精彩内容,请关注微信公众号:后端技术小屋 一文读懂clickhouse集群监控 常言道,兵马未至,粮草先行,在clickhouse上生产环境之前,我们就得制定好相关的监控方案,包括metric采集 ...
- 一文读懂HTTP/2及HTTP/3特性
摘要: 学习 HTTP/2 与 HTTP/3. 前言 HTTP/2 相比于 HTTP/1,可以说是大幅度提高了网页的性能,只需要升级到该协议就可以减少很多之前需要做的性能优化工作,当然兼容问题以及如何 ...
- [转帖]一文读懂 HTTP/2
一文读懂 HTTP/2 http://support.upyun.com/hc/kb/article/1048799/ 又小拍 • 发表于:2017年05月18日 15:34:45 • 更新于:201 ...
随机推荐
- shell 字符串比较与脚本 too many arguments 报错
一.问题 最近在写 shell 脚本的时候,遇到了一些小问题,就是我在判断一个字符串是否为空的时候经常报下面的错,程序是正常执行了,但是有这个提示很蛋疼,下面就是看看是什么问题导致的? [: too ...
- [考试反思]1025csp-s模拟测试87:生存
想起一句话 课上求生存,课下求发展 发展还好说,如何生存? 生存很困难... 没什么可抱怨的.有AK的.高分的也很多. 该说的在<Dust>里说完了,安静会吧. 这场rank43怎么追? ...
- [考试反思]0926csp-s模拟测试52:审判
也好. 该来的迟早会来. 反思再说吧. 向下跳过直到另一条分界线 %%%cbx也拿到了他的第一个AK了呢. 我的还是遥不可及. 我恨你,DeepinC. 我恨透你了.你亲手埋葬所有希望,令我无比气愤. ...
- [校内自测 NOIP模拟题] chenzeyu97要请客(单调栈)
题目描述 chenzeyu97的家可以看成是一个n*m的矩阵,每块区域都有独一无二的海拔高度h(h>0)!其最大值为n*m. 现在他要选择一个子矩阵摆放一张桌子,在他眼里,这样摆放桌子的美观度为 ...
- 磁盘冗余阵列之RAID5的配置
1988年由加利福尼亚大学伯克利分校发表的文章首次提到并定义了RAID,当今CPU性能每年可提升30%-50%但硬盘仅提升7%,渐渐的已经成为计算机整体性能的瓶颈,并且为了避免硬盘的突然损坏导致数据丢 ...
- 《计算机网络 自顶向下方法》 第6章 链路层和局域网 Part2
待补充完善 Web 页面的请求历程 应用层 报文.主机 运输层 报文段. 网络层 数据报.路由器.IP 地址 链路层 以太网帧.交换机.MAC 地址 步骤 1)到 4) ...
- thinkphp volist标签中加if判断的写法
<if condition="$vo['devstatus'] eq 1">在线<else /> 离线</if> IF标签用法 <if c ...
- PHP代码安全有必要了解下
攻击者通过构造恶意SQL命令发送到数据库,如果程序未对用户输入的 SQL命令执行判断过滤,那么生成的SQL语句可能会绕过安全性检查,插入其他用于修改后端数据库的语句,并可能执行系统命令,从而对系统造成 ...
- spark-宽依赖和窄依赖
一.窄依赖(Narrow Dependency,) 即一个RDD,对它的父RDD,只有简单的一对一的依赖关系.也就是说, RDD的每个partition ,仅仅依赖于父RDD中的一个partition ...
- lqb 基础练习 字母图形 (循环)
基础练习 字母图形 时间限制:1.0s 内存限制:256.0MB 问题描述 利用字母可以组成一些美丽的图形,下面给出了一个例子: ABCDEFG BABCDEF CBABCDE DCBAB ...