
詳解python使用Nginx和uWSGI來運行Python應(yīng)用
uWSGI是一個Web應(yīng)用服務(wù)器,它具有應(yīng)用服務(wù)器,代理,進程管理及應(yīng)用監(jiān)控等功能。它支持WSGI協(xié)議,同時它也支持自有的uWSGI協(xié)議,該協(xié)議據(jù)說性能非常高,而且內(nèi)存占用率低,為mod_wsgi的一半左右,我沒有實測過。它還支持多應(yīng)用的管理及應(yīng)用的性能監(jiān)控。雖然uWSGI本身就可以直接用來當Web服務(wù)器,但一般建議將其作為應(yīng)用服務(wù)器配合Nginx一起使用,這樣可以更好的發(fā)揮Nginx在Web端的強大功能。本文我們就來介紹如何搭建uWSGI+Ngnix環(huán)境來運行Python應(yīng)用。
安裝uWSGI
pip install uwsgi
讓我們來寫個Hello World的WSGI應(yīng)用,并保存在”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中運行它,執(zhí)行命令:
uwsgi --http :9090 --wsgi-file server.py
然后打開瀏覽器,訪問”http://localhost:9090″,你就可以看到”Hello World!”字樣了。
上面的命令中”- -http”參數(shù)指定了HTTP監(jiān)聽地址和端口,”- -wsgi-file”參數(shù)指定了WSGI應(yīng)用程序入口,uWSGI會自動搜尋名為”application”的應(yīng)用對象并調(diào)用它。
更進一步,uWSGI可以支持多進程和多線程的方式啟動應(yīng)用,也可以監(jiān)控應(yīng)用的運行狀態(tài)。我們將啟動的命令改為:
復(fù)制代碼 代碼如下:
$ uwsgi --http :9090 --wsgi-file server.py --master --processes 4 --threads 2 --stats 127.0.0.1:9191
執(zhí)行它后,uWSGI將啟動4個應(yīng)用進程,每個進程有2個線程,和一個master主進程(監(jiān)控其他進程狀態(tài),如果有進程死了,則重啟)。同時,你可以訪問”127.0.0.1:9191″來獲取JSON格式的應(yīng)用運行信息,uWSGI還提供了工具命令”uwsgitop”來像top一樣監(jiān)控應(yīng)用運行狀態(tài),你可以用pip來安裝它。
上面的命令參數(shù)太多了,我們可以將參數(shù)寫在配置文件里,啟動uWSGI時指定配置文件即可。配置文件可以是鍵值對的格式,也可以是XML,YAML格式,這里我們使用鍵值對的格式。讓我們創(chuàng)建一個配置文件”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的安裝可以參考這篇文章,文本采用的環(huán)境就是Ubuntu Linux,對于其他系統(tǒng)如Mac,基本上差不太多
首先,我們將uWSGI的HTTP端口監(jiān)聽改為socket端口監(jiān)聽,即將配置文件中的”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會將收到的所有請求都轉(zhuǎn)發(fā)到”127.0.0.1:3031″端口上,即uWSGI服務(wù)器上?,F(xiàn)在讓我們重啟Nginx,并啟動uWSGI服務(wù)器:
$ sudo service nginx restart
$ uwsgi myapp.ini
訪問”http://localhost”,我們會再次看到”Hello World!”。
運行Flask應(yīng)用
其實很簡單,只要將上例中server.py的內(nèi)容改為Flask應(yīng)用即可,當然你需要先把Flask包安裝好:
from flask import Flask
application = Flask(__name__)
@application.route('/')
def index():
return '<h1>Hello World</h1>'
很多人習(xí)慣將Flask應(yīng)用對象取名為”app”,但是WSGI標準是”application”。uWSGI提供了一個功能,可以指定應(yīng)用對象,方法就是在配置文件中加上”callable”項:
[uwsgi]
...
callable=app
現(xiàn)在,我們的Flask應(yīng)用就可以使用”app”作為對象名了
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '<h1>Hello World</h1>'
使用Python虛擬環(huán)境
我們永遠都是建議采用虛擬環(huán)境來避免應(yīng)用間沖突,uWSGI可以非常容易做到這點,就是在配置文件中加上”virtualenv”項:
[uwsgi]
...
virtualenv=/home/bjhee/virtualenv
部署多個應(yīng)用
一個Nginx中,可以同時運行多個應(yīng)用,不一定是Python的應(yīng)用。我們期望通過不同的路徑來路由不同的應(yīng)用,因此就不能像上例那樣直接修改根目錄的配置。假設(shè)我們希望通過”http://localhost/myapp”來訪問我們的應(yīng)用,首先要在Nginx的配置文件中,加入下面的內(nèi)容:
location /myapp {
include uwsgi_params;
uwsgi_param SCRIPT_NAME /myapp;
uwsgi_pass 127.0.0.1:3031;
}
這里我們定義了一個uWSGI參數(shù)”SCRIPT_NAME”,值為應(yīng)用的路徑”/myapp”。接下來,在uWSGI的啟動配置中,去掉”wsgi-file”項,并加上:
[uwsgi]
...
mount=/myapp=server.py
manage-script-name=true
“mount”參數(shù)表示將”/myapp”地址路由到”server.py”中,”manage-script-name”參數(shù)表示啟用之前在Nginx里配置的”SCRIPT_NAME”參數(shù)。再次重啟Nginx和uWSGI,你就可以通過”http://localhost/myapp”來訪問應(yīng)用了。
補充內(nèi)容
上面的所有例子中,我們是通過”127.0.0.1:3031″Socket端口來連接Nginx和uWSGI的,其實我們也可以采用socket文件的方式,這樣可以不用寫死端口。在uWSGI的啟動配置中,我們要修改”socket”項:
[uwsgi]
socket=/tmp/uwsgi.sock
...
啟動uWSGI服務(wù)器后,它會自動創(chuàng)建一個”/tmp/uwsgi.sock”文件。然后讓我們修改Nginx配置文件,將”uwsgi_pass”配置項改為文件:
location /myapp {
include uwsgi_params;
uwsgi_param SCRIPT_NAME /myapp;
uwsgi_pass unix:/tmp/uwsgi.sock;
}
重啟Nginx服務(wù)器即可。這里我開始一直沒跑通,研究了好久才發(fā)現(xiàn),Nginx的用戶(默認的www-date:adm),必須要對該文件有讀寫的權(quán)限才行。因為運行uWSGI的用戶與運行Nginx的用戶不一樣,而”/tmp/uwsgi.sock”是由uWSGI的用戶創(chuàng)建的,導(dǎo)致Nginx沒有足夠的權(quán)限。如果朋友們也遇到同樣的問題,那就只能chmod了。
另外,還是要提一下”.egg”包的解壓縮臨時目錄,我們在介紹mod_wsgi的最后提到過,在uWSGI應(yīng)用中也一樣,Linux上默認是在用戶主目錄下,比如”/home/bjhee/.python-eggs”。你可以通過設(shè)置系統(tǒng)環(huán)境變量”PYTHON_EGG_CACHE”來改變它。
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
LSTM 模型輸入長度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)家族中,長短期記憶網(wǎng)絡(luò)(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報考條件詳解與準備指南? ? 在數(shù)據(jù)驅(qū)動決策的時代浪潮下,CDA 數(shù)據(jù)分析師認證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計的實用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實施重大更新。 此次更新旨在確保認 ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務(wù)的價值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預(yù)測分析中的應(yīng)用:從數(shù)據(jù)查詢到趨勢預(yù)判? ? 在數(shù)據(jù)驅(qū)動決策的時代,預(yù)測分析作為挖掘數(shù)據(jù)潛在價值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點,而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報考到取證的全攻略? 在數(shù)字經(jīng)濟蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢性檢驗:捕捉數(shù)據(jù)背后的時間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢性檢驗如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時間維度的精準切片? ? 在數(shù)據(jù)的世界里,時間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準 ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應(yīng)用與實戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗:數(shù)據(jù)趨勢與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準確捕捉數(shù)據(jù)的趨勢變化以及識別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認證作為國內(nèi)權(quán)威的數(shù)據(jù)分析能力認證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應(yīng)對策略? 長短期記憶網(wǎng)絡(luò)(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的一種變體,憑借獨特的門控機制,在 ...
2025-07-07統(tǒng)計學(xué)方法在市場調(diào)研數(shù)據(jù)中的深度應(yīng)用? 市場調(diào)研是企業(yè)洞察市場動態(tài)、了解消費者需求的重要途徑,而統(tǒng)計學(xué)方法則是市場調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書考試全攻略? 在數(shù)字化浪潮席卷全球的當下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03