
詳解python使用Nginx和uWSGI來運行Python應用
uWSGI是一個Web應用服務器,它具有應用服務器,代理,進程管理及應用監控等功能。它支持WSGI協議,同時它也支持自有的uWSGI協議,該協議據說性能非常高,而且內存占用率低,為mod_wsgi的一半左右,我沒有實測過。它還支持多應用的管理及應用的性能監控。雖然uWSGI本身就可以直接用來當Web服務器,但一般建議將其作為應用服務器配合Nginx一起使用,這樣可以更好的發揮Nginx在Web端的強大功能。本文我們就來介紹如何搭建uWSGI+Ngnix環境來運行Python應用。
安裝uWSGI
pip install uwsgi
讓我們來寫個Hello World的WSGI應用,并保存在”server.py”文件中:
def application(environ, start_response):
status = '200 OK'
output = 'Hello World!'
response_headers = [('Content-type', 'text/plain'),
('Content-Length', str(len(output)))]
start_response(status, response_headers)
return [output]
讓我們在uWSGI中運行它,執行命令:
uwsgi --http :9090 --wsgi-file server.py
然后打開瀏覽器,訪問”http://localhost:9090″,你就可以看到”Hello World!”字樣了。
上面的命令中”- -http”參數指定了HTTP監聽地址和端口,”- -wsgi-file”參數指定了WSGI應用程序入口,uWSGI會自動搜尋名為”application”的應用對象并調用它。
更進一步,uWSGI可以支持多進程和多線程的方式啟動應用,也可以監控應用的運行狀態。我們將啟動的命令改為:
復制代碼 代碼如下:
$ uwsgi --http :9090 --wsgi-file server.py --master --processes 4 --threads 2 --stats 127.0.0.1:9191
執行它后,uWSGI將啟動4個應用進程,每個進程有2個線程,和一個master主進程(監控其他進程狀態,如果有進程死了,則重啟)。同時,你可以訪問”127.0.0.1:9191″來獲取JSON格式的應用運行信息,uWSGI還提供了工具命令”uwsgitop”來像top一樣監控應用運行狀態,你可以用pip來安裝它。
上面的命令參數太多了,我們可以將參數寫在配置文件里,啟動uWSGI時指定配置文件即可。配置文件可以是鍵值對的格式,也可以是XML,YAML格式,這里我們使用鍵值對的格式。讓我們創建一個配置文件”myapp.ini”:
[uwsgi]
http=:9090
wsgi-file=server.py
master=true
processes=4
threads=2
stats=127.0.0.1:9191
然后就可以將啟動命令簡化為:
$ uwsgi myapp.ini
配置Nginx
Nginx的安裝可以參考這篇文章,文本采用的環境就是Ubuntu Linux,對于其他系統如Mac,基本上差不太多
首先,我們將uWSGI的HTTP端口監聽改為socket端口監聽,即將配置文件中的”http”項去掉,改為”socket”項:
[uwsgi]
socket=127.0.0.1:3031
wsgi-file=server.py
master=true
processes=4
threads=2
stats=127.0.0.1:9191
然后,打開Nginx的配置文件,Ubuntu上默認是”/etc/nginx/sites-enabled/default”文件,將其中的根路徑部分配置為:
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:3031;
}
這段配置表明Nginx會將收到的所有請求都轉發到”127.0.0.1:3031″端口上,即uWSGI服務器上?,F在讓我們重啟Nginx,并啟動uWSGI服務器:
$ sudo service nginx restart
$ uwsgi myapp.ini
訪問”http://localhost”,我們會再次看到”Hello World!”。
運行Flask應用
其實很簡單,只要將上例中server.py的內容改為Flask應用即可,當然你需要先把Flask包安裝好:
from flask import Flask
application = Flask(__name__)
@application.route('/')
def index():
return '<h1>Hello World</h1>'
很多人習慣將Flask應用對象取名為”app”,但是WSGI標準是”application”。uWSGI提供了一個功能,可以指定應用對象,方法就是在配置文件中加上”callable”項:
[uwsgi]
...
callable=app
現在,我們的Flask應用就可以使用”app”作為對象名了
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '<h1>Hello World</h1>'
使用Python虛擬環境
我們永遠都是建議采用虛擬環境來避免應用間沖突,uWSGI可以非常容易做到這點,就是在配置文件中加上”virtualenv”項:
[uwsgi]
...
virtualenv=/home/bjhee/virtualenv
部署多個應用
一個Nginx中,可以同時運行多個應用,不一定是Python的應用。我們期望通過不同的路徑來路由不同的應用,因此就不能像上例那樣直接修改根目錄的配置。假設我們希望通過”http://localhost/myapp”來訪問我們的應用,首先要在Nginx的配置文件中,加入下面的內容:
location /myapp {
include uwsgi_params;
uwsgi_param SCRIPT_NAME /myapp;
uwsgi_pass 127.0.0.1:3031;
}
這里我們定義了一個uWSGI參數”SCRIPT_NAME”,值為應用的路徑”/myapp”。接下來,在uWSGI的啟動配置中,去掉”wsgi-file”項,并加上:
[uwsgi]
...
mount=/myapp=server.py
manage-script-name=true
“mount”參數表示將”/myapp”地址路由到”server.py”中,”manage-script-name”參數表示啟用之前在Nginx里配置的”SCRIPT_NAME”參數。再次重啟Nginx和uWSGI,你就可以通過”http://localhost/myapp”來訪問應用了。
補充內容
上面的所有例子中,我們是通過”127.0.0.1:3031″Socket端口來連接Nginx和uWSGI的,其實我們也可以采用socket文件的方式,這樣可以不用寫死端口。在uWSGI的啟動配置中,我們要修改”socket”項:
[uwsgi]
socket=/tmp/uwsgi.sock
...
啟動uWSGI服務器后,它會自動創建一個”/tmp/uwsgi.sock”文件。然后讓我們修改Nginx配置文件,將”uwsgi_pass”配置項改為文件:
location /myapp {
include uwsgi_params;
uwsgi_param SCRIPT_NAME /myapp;
uwsgi_pass unix:/tmp/uwsgi.sock;
}
重啟Nginx服務器即可。這里我開始一直沒跑通,研究了好久才發現,Nginx的用戶(默認的www-date:adm),必須要對該文件有讀寫的權限才行。因為運行uWSGI的用戶與運行Nginx的用戶不一樣,而”/tmp/uwsgi.sock”是由uWSGI的用戶創建的,導致Nginx沒有足夠的權限。如果朋友們也遇到同樣的問題,那就只能chmod了。
另外,還是要提一下”.egg”包的解壓縮臨時目錄,我們在介紹mod_wsgi的最后提到過,在uWSGI應用中也一樣,Linux上默認是在用戶主目錄下,比如”/home/bjhee/.python-eggs”。你可以通過設置系統環境變量”PYTHON_EGG_CACHE”來改變它。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25