关于 WSGI、uwsgi和uWSGI的区别及基于 uWSGI和gunicorn 部署python web 简述
關(guān)于 WSGI、uwsgi和uWSGI的區(qū)別及基于 uWSGI和gunicorn 部署python web 簡(jiǎn)述
?
引言
最近基于 Flask Web框架在開發(fā)一個(gè)后端項(xiàng)目,在Web Server和 Flask 應(yīng)用程序交互的過程中總會(huì)碰到本文題目提及到WSGI、uwsgi和uWSGI這幾個(gè)概念,整理如下。
WSGI
英文全稱:Web Server Gateway Interface,Web服務(wù)網(wǎng)管接口,簡(jiǎn)單來說它是一種Web服務(wù)器和應(yīng)用程序間的通信規(guī)范。
uwsgi
uwsgi是一種通信協(xié)議,不過跟WSGI分屬兩種東西,該協(xié)議下速度比較快。
uWSGI
uWSGI是一個(gè)Web Server,并且獨(dú)占uwsgi協(xié)議,但是同時(shí)支持WSGI協(xié)議、HTTP協(xié)議等,它的功能是把HTTP協(xié)議轉(zhuǎn)化成語言支持的網(wǎng)絡(luò)協(xié)議供python使用。
?
雖然 Flask 非常容易上手,它自帶的app.run(host="0.0.0.0", port=7001)用來調(diào)試非常方便,但是用于生產(chǎn)環(huán)境無論是處理高并發(fā)還是魯棒性都有所欠缺,一般會(huì)配合WGSI容器來進(jìn)行[生產(chǎn)環(huán)境的部署]
?
uWSGI的使用
在做Django項(xiàng)目時(shí),一般測(cè)試開發(fā)我們直接用Django內(nèi)嵌的Web Server即可,但是如果項(xiàng)目要上生產(chǎn)環(huán)境,考慮并發(fā)等性能時(shí),我們可能需要uwsgi和nginx,下面只說明uwsgi的常用用法,至于nginx的配置筆者后續(xù)準(zhǔn)備專門寫一篇博文來講。
1. 安裝
?
pip install uwsgi2. 配置
uwsgi執(zhí)行一般有兩種方式:命令行和文件配置,但是命令行可能需要識(shí)記很多參數(shù),因此采用文件配置是更通用的做法,文件格式支持很多種比如ini、xml、yaml等,筆者建議還是采用比較簡(jiǎn)單key-value形式ini模式,下面給出一個(gè)簡(jiǎn)單的uwsgi ini配置實(shí)例:
?
[uwsgi] socket = 127.0.0.1:8001 master = false chdir = /var/www/cmpvirtmgr/ module = cmpvirtmgr.wsgi home = /var/www/env workers = 2 reload-mercy = 10 vacuum = true max-requests = 1000 limit-as = 512 buffer-size = 30000 pidfile = /etc/uwsgi/uwsgi.pid執(zhí)行:uwsgi --ini /path/to/uwsgi.ini
參數(shù)解釋:
- socket:socket文件,也可以是地址+端口;
- master:是否啟動(dòng)主進(jìn)程來管理其他進(jìn)程;
- chdir:項(xiàng)目的根目錄;
- module:wsgi文件相對(duì)路徑;
- home:虛擬環(huán)境目錄;
- workers:開啟的進(jìn)程數(shù)量;
- reload-mercy:設(shè)置在平滑的重啟(直到接收到的請(qǐng)求處理完才重啟)一個(gè)工作子進(jìn)程中,等待這個(gè)工作結(jié)束的最長(zhǎng)秒數(shù);
- vacuum:服務(wù)結(jié)束后時(shí)候刪除對(duì)應(yīng)的socket和pid文件;
- max_requests:每個(gè)工作進(jìn)程設(shè)置的請(qǐng)求上限;
- limit_as:限制每個(gè)uwsgi進(jìn)程占用的虛擬內(nèi)存數(shù)目;
- buffer_size:設(shè)置用于uwsgi包解析的內(nèi)部緩存區(qū)大小;
- pid_file:指定pid文件;
- harakiri:請(qǐng)求的超時(shí)時(shí)間;
- daemonize:進(jìn)程后臺(tái)執(zhí)行,并保存日志到特定路徑;如果uwsgi進(jìn)程被supervisor管理,不能設(shè)置該參數(shù);
更多uwsgi參數(shù)可參考官方文檔:https://uwsgi-docs.readthedocs.io/en/latest/
使用gunicorn部署flask項(xiàng)目
?
1、WSGI協(xié)議
Web框架致力于如何生成HTML代碼或生成基于 Restful 的 API 接口數(shù)據(jù),而Web服務(wù)器用于處理和響應(yīng)HTTP請(qǐng)求。Web框架和Web服務(wù)器之間的通信,需要一套雙方都遵守的接口協(xié)議。WSGI協(xié)議就是用來統(tǒng)一這兩者的接口的。
2、WSGI容器
常用的WSGI容器有Gunicorn和uWSGI,但Gunicorn直接用命令啟動(dòng),不需要編寫配置文件,相對(duì)uWSGI要容易很多,所以這里我也選擇用Gunicorn作為容器。
3、gunicorn介紹
gunicorn是一個(gè)python Wsgi http server,只支持在Unix系統(tǒng)上運(yùn)行,來源于Ruby的unicorn項(xiàng)目。Gunicorn使用prefork master-worker模型(在gunicorn中,master被稱為arbiter),能夠與各種wsgi web框架協(xié)作。
4、gunicorn安裝
gunicorn安裝非常簡(jiǎn)單,使用命令pip install gunicorn即可。一般使用它,主要是為使用其異步的worker模型,還需要安裝對(duì)應(yīng)的異步模塊。
$ pip install gunicorn $ pip install greenlet # 使用異步必須安裝 $ pip install eventlet # 使用eventlet workers $ pip install gevent # 使用gevent workers5、gunicorn使用
這里使用gunicorn來部署一個(gè)flask項(xiàng)目舉例,此處flask框架的使用不過多闡述,不是本文的重點(diǎn)。
如下例子,保存為app.py
from flask import Flask app = Flask(__name__)@app.route("/") def hello():return "Hello World!"gunicorn通常使用的參數(shù)如下:
-c CONFIG, --config=CONFIG # 設(shè)定配置文件。 -b BIND, --bind=BIND # 設(shè)定服務(wù)需要綁定的端口。建議使用HOST:PORT。 -w WORKERS, --workers=WORKERS # 設(shè)置工作進(jìn)程數(shù)。建議服務(wù)器每一個(gè)核心可以設(shè)置2-4個(gè)。 -k MODULE # 選定異步工作方式使用的模塊。在shell中輸入你的啟動(dòng)配置,比如:
$ gunicorn -w 3 -b 127.0.0.1:8080 app:app # 此處app:app中,第一個(gè)app為flask項(xiàng)目實(shí)例所在的啟動(dòng)模塊,第二個(gè)app為生成的flask項(xiàng)目實(shí)例這樣運(yùn)行正常就可以啟動(dòng)服務(wù)器了。
6、綁定端口
linux通常會(huì)禁止綁定使用1024以下的端口,除非在root用戶權(quán)限。很多人在使用gunicorn時(shí)試圖將其綁定到80或者443端口,發(fā)現(xiàn)無效。如果想綁定到這些端口,常見的有如下的幾種方法:
- 使用Nginx代理轉(zhuǎn)發(fā)。
- sudo啟動(dòng)gunicorn。
- 安裝額外的程序。
7、結(jié)束gunicorn服務(wù)進(jìn)程
使用ps -ef | grep gunicorn命令找出gunicorn所有進(jìn)程。
[root@VM_0_12_centos ~]# ps -ef | grep gunicorn root 16843 23035 0 Oct14 ? 00:00:02 /root/Envs/myflask/bin/python3.6 /root/Envs/myflask/bin/gunicorn -w 3 -b 172.17.0.12:80 app:app root 22445 23035 0 Oct04 ? 00:00:15 /root/Envs/myflask/bin/python3.6 /root/Envs/myflask/bin/gunicorn -w 3 -b 172.17.0.12:80 app:app root 22581 23035 0 Oct11 ? 00:00:05 /root/Envs/myflask/bin/python3.6 /root/Envs/myflask/bin/gunicorn -w 3 -b 172.17.0.12:80 app:app root 23035 1 0 Sep27 ? 00:04:11 /root/Envs/myflask/bin/python3.6 /root/Envs/myflask/bin/gunicorn -w 3 -b 172.17.0.12:80 app:app然后使用 kill -9 進(jìn)程ID 命令來殺掉進(jìn)程,注意,我們找到主進(jìn)程殺掉即可,子進(jìn)程會(huì)隨之結(jié)束,在上例中,主進(jìn)程號(hào)為23035.
[root@VM_0_12_centos ~]# kill -9 23035 [root@VM_0_12_centos ~]# ps -ef | grep gunicorn殺掉進(jìn)程后,稍等幾秒,再使用ps -ef | grep gunicorn查看,發(fā)現(xiàn)gunicorn服務(wù)進(jìn)程已全部殺掉。
總結(jié)
以上是生活随笔為你收集整理的关于 WSGI、uwsgi和uWSGI的区别及基于 uWSGI和gunicorn 部署python web 简述的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【C++】递归打印杨辉三角
- 下一篇: 【Python】Matplotlib绘图