介绍Python Web中WSGI协议
- 更新时间:2020-03-07 17:07:55
- 编辑:融宜然
本文实例讲述了Python Web编程之WSGI协议。分享给大家供大家参考,具体如下:
WSGI简介
Web框架和Wen服务器之间需要进行通信,如果在设计时它们之间无法相互匹配,那么对框架的选择就会限制对Web服务器的选择,这显然是不合理的。这时候需要设计一套双方都遵守的接口。WSGI是Python Web Server Gateway Interface的简称。WSGI标准在PEP 333中定义并被许多框架实现,它规定了一种在Web服务器之间具有可移植性。在后来的PEP 3333中添加了Python 3的支持和更多相关的说明。有了通用的WSGI协议,Web开发者就能够任意选择适合自己的组合,而Web服务器和Web框架的开发者们也能够把精力集中到各自的领域。
常见的WSGI容器
WSGI是一个同步接口,所以Tornado的WSGI容器是无法实现异步的。主流的选择是Gunicorn和uWSGI。
Gunicorn
Gunicorn易于配置,兼容性好,CPU消耗很少,在豆瓣使用广泛。它支持多种Worker模式,推荐的模式有如如下几种:
- 同步Worker:默认模式,也就是一次只处理一个请求
- 异步Worker:通过Eventlet、Gevent实现的异步模式
- 异步IO Worker:目前支持gthread和gaiohttp两种类型
安装Gunicorn:
pip install gunicorn
Gunicorn的启动非常简单,语法如下:
gunicorn [OPTIONS] MODULE_NAME:VARIABLE_NAME
举个栗子,manager.py:
from flask import Flask app = Flask(__name__) @app.route("/") def hello_world(): return "Hello World" if __name__ == "__main__": app.run()
启动应用:
gunicorn manager:app -b 0.0.0.0:9000
亦或者指定Worker数量启动:
gunicorn --workers=3 manager:app -b 0.0.0.0:9000
app为Flask实例的名称,Worker的数量推荐值是CPU的个数*2+1,CPU个数使用如下的方式获取:
python -c 'import multiprocessing; print multiprocessing.cpu_count()'
uWSGI
uWSGI是使用C编写的,显示了自有的uwsgi协议的Web服务器。它自带丰富的组件,其中核心组件包含进程管理、监控、IPC等功能,实现应用服务器接口的请求插件支持多种语言和平台,比如WSGI、Rack、Lua WSAPI,网管组件实现了负载均衡、代理和理由功能。
安装uWSGI
pip install uwsgi
使用uWSGI启动应用:
上面的命令表示启动了4个进程,每个进程使用2个线程,而且开启了5000的Web接口,返回监控uWSGI的信息,一级不同进程和线程的详细使用情况。使用uWSGI有两点十分重要:
–http-socket
和–http
其实是完全不同的两个选项。如果想直接裸跑uWSGI,应该使用–http
,它产生一个额外的进程将请求转发给Workers,如果希望它被反向代理(比如和Nginx一起使用),应该使用–http-socket
。
合理的进程数和线程数不能简单的通过CPU * 2来计算得出,需要不断的尝试而找到最佳值。
uWSGI命令常用参数如下:
参数名 | 含义 |
---|---|
–http | 协议类型和端口号 |
–processes | 开启的进程数量 |
–callable | uWSGI加载的模块哪个变量将被调用 |
–workers | 开启的进行数量,等同于processes |
–chdir | 指定运行目录 |
–wsgi-file | 载入wsgi-file(加载wsgi.py文件) |
–stats | 在指定的地址上开启状态服务 |
–threads | 开启的线程数量 |
–master | 允许主进程存在 |
–daemonize | 使进程在后台运行,并将日志输出到指定的日志文件或者UDP服务器 |
–pidfile | 指定PID文件的位置,记录主进程的PID号 |
–vacuum | 当服务器退出时自动清理环境,删除Unix Socket文件和PID文件 |
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python Socket编程技巧总结》、《Python URL操作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
相关教程
-
python培训机构哪家比较正规
其实没有好不好,只有合适不合适,选择培训机构的话,最关键的就是根据自己的情况,然后综合口碑、讲师、环境、课程安排等方面进行考虑,您可以试听课程,看看是否符合您的要求。
发布时间:2019-06-26
-
python爬虫selenium模块详解
这篇文章主要介绍了python爬虫selenium模块详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
发布时间:2021-05-02
-
Python并行编程参考手册
本书以Python为基础,对并行编程领域的各项技术与知识进行了广泛且深入的讲解,从原理到实践系统化地对并行编程技术进行了层层剖析,是提升并行编程技能的一本不可多得的好书,欢迎下载
大小:41.4 MBPython编程电子书
-
Python自动化运维:技术与最佳实践
这书在我国运维管理行业将有里程碑式的关键实际意义:不仅,它是中国第一本从纵、深和实践活动视角讨论Python在运维管理行业运用的经典著作;不仅这书的创作者是我国运维管理行业的超
大小:150.4 MBPython电子书
-
Python即学即用
本书采用了即学即用的方式讲解Python,包含Python语言知识及大数据使用的numpy、pandas、pytables;Web编程框架web.py、操作postgresql数据库等,特别适合软件开发人员和数据分析工程师阅读
大小:99 MBPython编程电子书
-
Python网络爬虫实战
这书从Python3.6.4的安裝刚开始,详尽解读了Python从简易程序流程拓宽到Python爬虫技术的过程。这书从实战演练来看,依据不一样的要求选择不一样的网络爬虫,有目的性地解读了几类Python爬虫技
大小:50.9 MBPython爬虫电子书
-
数据结构与算法:Python语言实现
这书选用Python語言详细介绍数据结构和优化算法,包含其设计构思、剖析和执行。这书源码简约、确立,面向对象编程的见解围绕自始至终,根据承继*底限地提升编码器重,一起突显不一样抽
大小:32.9 MB数据结构
-
Python+Spark2.0+Hadoop机器学习与大数据实战
本书从浅显易懂的“大数据和机器学习”原理说明入手,讲述大数据和机器学习的基本概念,浅显易懂的原理介绍加上Step by Step 实机操作、范例程序详细解说,实现降低机器学习与大数据技术
大小:109 MBHadoop电子书
-
Python微服务开发
Python微服务开发 资料配套源码 应用Python小工具生态体系减少微服务多元性的好用方式 Web运用常常布署到云主机,运用编码必须与众多第三方平台服务项目互动。从基础理论上讲,可应用分布
大小:117 KB微服务电子书