本文首發(fā)于公眾號:Hunter后端
原文鏈接:Django筆記四十三之使用uWSGI部署Django系統(tǒng)
目前部署 Django 的方式一般來說是使用 Nginx + uWSGI + Django 來實現(xiàn)。
處理流程是,當(dāng)一個請求發(fā)送過來會先經(jīng)過 Nginx,如果是靜態(tài)文件請求,Nginx 這一層直接處理,如果是后端動態(tài)接口,則會發(fā)送至 uWSGI,而 uWSGI 是一個 web 服務(wù)器,它實現(xiàn)的操作是將 HTTP 請求轉(zhuǎn)換成 Python 支持的網(wǎng)絡(luò)協(xié)議,比如 WSGI 協(xié)議。
以下是本篇筆記目錄:
- Nginx 和 uWSGI
- WSGI、uWSGI 和 uwsgi
- uWSGI 示例及啟動
- 配置項詳解
1、Nginx 和 uWSGI
使用 Nginx 相當(dāng)于實現(xiàn)了一次反向代理,也可以通過使用 Nginx 實現(xiàn)負載均衡,將請求分配給不同的后端服務(wù),同時靜態(tài)文件和動態(tài)接口分開請求,提高服務(wù)響應(yīng)性能。
如果部署操作直接使用 uWSGI + Django,那么 uWSGI 就相當(dāng)于一個 web 服務(wù)器,用于直接處理 HTTP 請求。如果是配合 Nginx 使用,相當(dāng)于是一個中間件的作用,起到轉(zhuǎn)發(fā)來自 Nginx 請求的作用。
2、WSGI、uWSGI 和 uwsgi
接下來理解一下 uWSGI,WSGI 和 uwsgi 這幾個概念。
WSGI
web server gateway interface,web 服務(wù)器網(wǎng)關(guān)接口,是一種協(xié)議規(guī)范,是用于 wsgi 服務(wù)器(比如 uWSGI) 和 wsgi 應(yīng)用(比如 Django)之間進行通信的規(guī)范。
uWSGI
web 服務(wù)器,或者叫 wsgi 服務(wù)器,實現(xiàn) http 協(xié)議,用于接收 http 請求并能夠解析信息。要將信息發(fā)給 Django,必須要用到 WSGI 協(xié)議,所以同時也可以實現(xiàn) WSGI 協(xié)議。
uwsgi
是 uWSGI 服務(wù)器自有的線路協(xié)議,用于與 Nginx 等代理服務(wù)器通信。
3、uWSGI 示例及啟動
我們可以通過 uWSGI 命令,將參數(shù)都寫入命令行直接運行,也可以將配置項寫入配置文件,用 uWSGI 直接獲取配置信息,這里我們介紹都寫入配置文件的方法來操作。
1、uWSGI 安裝
首先我們需要安裝一下 uWSGI:
pip3 install uwsgi -i https://mirrors.aliyun.com/pypi/simple/
2、配置示例及啟動
假設(shè)我們的 Django 系統(tǒng)目錄為 /path/to/hunter/
,我們在該目錄下創(chuàng)建一個文件 uwsgi.ini
。
uwsgi.ini 內(nèi)容如下:
# uwsgi.ini
[uwsgi]
http = :9898
chdir = /path/to/hunter/
wsgi-file = hunter/wsgi.py
master=true
processes = 4
threads = 2
以上是一個簡單的可運行 uwsgi.ini 配置示例。
接著我們運行一下:
uwsgi uwsgi.ini
可以看到在 shell 的前臺輸出下面的信息:
*** Starting uWSGI 2.0.21 (64bit) on [Mon Mar 20 00:14:08 2023] ***
...
...
*** uWSGI is running in multiple interpreter mode ***
spawned uWSGI master process (pid: 16291)
spawned uWSGI worker 1 (pid: 16295, cores: 2)
spawned uWSGI worker 2 (pid: 16296, cores: 2)
spawned uWSGI worker 3 (pid: 16299, cores: 2)
spawned uWSGI worker 4 (pid: 16301, cores: 2)
表示 uWSGI 已經(jīng)正常啟動,接著我們在瀏覽器訪問該地址的 9898 端口的 admin 頁面,可以看到?jīng)]有樣式的 admin 登錄頁面,如下:
4、配置項詳解
在這里我們是直接使用 uWSGI + Django 的方式啟動,所以首行是 http=:9898
,表示可以通過瀏覽器的方式訪問。
如果回頭我們使用 Nginx + uWSGI + Django 的方式啟動,這里就要改成 socket=:9898
。
chdir
chdir 參數(shù)指向的是我們項目根目錄
wsgi-file
這里我們填寫的是相對地址,文件是 Django 系統(tǒng)在創(chuàng)建項目時自動創(chuàng)建的。
master
表示的是啟動的 uWSGI 主進程是否開啟
processes
表示啟動的是進程數(shù),所以在啟動后輸出的信息里,會有主進程和四個進程的信息
threads
表示的線程數(shù),在上面的進程數(shù)后面 cores: 2
,輸出的就是線程信息。
除了上面這些參數(shù),我們還可以定義一些其他的參數(shù)
daemonize
daemonize 的值為一個地址,用于記錄 uWSGI 運行的日志,同時將服務(wù)在后臺運行。
daemonize = /var/log/uwsgi/xxx.log
static-map
static-map 參數(shù)作用是映射 Django 的靜態(tài)文件路徑,前面我們運行之后,訪問后臺 admin 界面,發(fā)現(xiàn)沒有前端樣式對不對,如果想要有樣式顯示,則需要先定義這個參數(shù),然后將 Django 的 admin 樣式文件遷移到指定文件,操作步驟如下:
1.定義 STATIC_ROOT
首先,我們需要在 settings.py 里定義 STATIC_ROOT,這個參數(shù)是一個路徑,表示我們在下一步需要將靜態(tài)文件集中到的文件路徑,假設(shè)我們需要把文件都集中到 /var/static/ 目錄下:
# settings.py
STATIC_ROOT = "/var/static/"
2.collectstatic命令
接下來執(zhí)行靜態(tài)文件集中的命令:
python3 manage.py collectstatic --no-input
本來前面的命令就可以了,但是執(zhí)行的時候會有選擇項需要我們選擇,在后續(xù)部署的時候,我們可以加上 --no-input 表示不需要提示輸入信息。
3.定義static-map
接下來我們定義 static-map 就可以映射靜態(tài)文件的地址,這樣,我們使用 uWSGI 部署 Django 后也可以訪問 admin 的靜態(tài)文件里。
static-map = /static/=/var/static/
stats
stats 參數(shù)后面接的內(nèi)容是端口,用于獲取 uWSGI 幾個 worker 的狀態(tài)信息。
如果想要到瀏覽器訪問的話還需要加一個 stats-http=true,如下:
stats = 127.0.0.1:9897
stats-http = true
timeout
關(guān)于 timeout 有兩個參數(shù),一個是 http-timeout,一個是 socket-timeout。
前面介紹了開放端口的時候,如果是 uWSGI 單獨使用,就使用 http,那么 timeout 就使用 http-timeout
如果是配合 Nginx 使用,那么就使用 socket-timeout。
它的單位是秒.
http-socket=60 # 60秒超時時間
注意:上面的計算運行超時之后,會斷開與前端的連接,但是后端還是會繼續(xù)執(zhí)行邏輯
harakiri
這個也是超時時間,但是與 timeout 不同的是,這個參數(shù)在超時之后斷開連接之后,同時后端也停止執(zhí)行運算,具體的操作是重啟該請求所在的進程。
它的單位也是秒。
max-requests
重啟進程的最大請求數(shù),比如我們設(shè)置:
max-requests=5000
那么在某個 worker 進程處理 5000 個請求之后則會重啟。
以上就是使用 uWSGI 啟動 Django 系統(tǒng)的示例及介紹,在之后的筆記中會再介紹如何使用 Nginx 進行操作,包括使用 Nginx 進行反向代理和負載均衡的配置。文章來源:http://www.zghlxwxcb.cn/news/detail-747574.html
如果想獲取更多相關(guān)文章,可掃碼關(guān)注閱讀:文章來源地址http://www.zghlxwxcb.cn/news/detail-747574.html
到了這里,關(guān)于Django筆記四十三之使用uWSGI部署Django系統(tǒng)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!