国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Django筆記四十三之使用uWSGI部署Django系統(tǒng)

這篇具有很好參考價值的文章主要介紹了Django筆記四十三之使用uWSGI部署Django系統(tǒng)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

本文首發(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é)議。

以下是本篇筆記目錄:

  1. Nginx 和 uWSGI
  2. WSGI、uWSGI 和 uwsgi
  3. uWSGI 示例及啟動
  4. 配置項詳解

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 進行反向代理和負載均衡的配置。

如果想獲取更多相關(guān)文章,可掃碼關(guān)注閱讀:
Django筆記四十三之使用uWSGI部署Django系統(tǒng)文章來源地址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)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Django使用uwsgi+nginx部署,admin沒有樣式解決辦法

    Django使用uwsgi+nginx部署,admin沒有樣式解決辦法

    若在服務(wù)器上部署的項目admin沒有樣式,則檢查下一下配置: settings uwsgi.ini urls nginx.conf } 如果使用了虛擬環(huán)境則修改nginx.conf文件中的/static/路徑為你虛擬環(huán)境的路徑,沒有使用虛擬環(huán)境則改為你python安裝路徑下的static 修改完后,cd/usr/sbin,使用./nginx -s reload,重啟nginx,重啟項目

    2024年02月14日
    瀏覽(24)
  • Python對接微信小程序V3接口進行支付,并使用uwsgi+nginx+django進行https部署

    網(wǎng)上找了很多教程,但是很亂很雜,并且教程資源很少且說的詳細。這里就記錄一下分享給大家 共分為以下幾個步驟: 目錄 一、開始前準(zhǔn)備信息 二、使用前端code獲取用戶的openid 三、對接小程序v3接口下單 四、小程序支付的回調(diào) 五、安裝并啟動uwsgi 六、安裝并啟動nginx 七、

    2024年02月12日
    瀏覽(28)
  • Django筆記四十一之Django中使用es

    前面在 Python 連接 es 的操作中,有過介紹如何使用 Python 代碼連接 es 以及對 es 數(shù)據(jù)進行增刪改查。 這一篇筆記介紹一下如何為 es 的 索引 index 定義一個 model,像 Django 里的 model 一樣使用 es。 因為本篇筆記要介紹的內(nèi)容是直接嵌入在 Django 系統(tǒng)使用,所以本篇筆記直接歸屬于

    2024年02月07日
    瀏覽(21)
  • 【Django】在Linux上部署Django(nginx+uwsgi)

    1.說明 關(guān)于在Linux上使用uwsgi部署Django的項目的過程并不難,主要是配置文件的寫法,尤其是nginx的配置文件,本文在Ubuntu20.04上通過uwsgi和nginx部署Django項目 2.安裝環(huán)境 安裝環(huán)境主要有Nginx、Python、MySQL、Redis,可以根據(jù)你的實際情況進行安裝 2.1 安裝nginx 大多數(shù)發(fā)行版Linux都支

    2024年02月12日
    瀏覽(27)
  • 【學(xué)習(xí)心得】如何用uwsgi快速部署Django

    問題描述: 有時候,只想快速的部署一個Django項目實現(xiàn)項目迭代開發(fā)。本文介紹不使用Nginx只用uwsgi如何實現(xiàn)Django項目的快速部署。 如果還不會創(chuàng)建Ubuntu中的Python虛擬環(huán)境,可以參考我之前的文章: 【學(xué)習(xí)心得】Linux下的Python虛擬環(huán)境搭建_linux python虛擬環(huán)境搭建 優(yōu)點:最簡

    2024年02月12日
    瀏覽(23)
  • linux centos7 django uwsgi 部署

    安裝這里就不多說,直接配置問題及所遇到問題總結(jié) django 項目 manage.py目錄新建uwsgi.ini文件 uwsgi配置 [uwsgi] socket = 127.0.0.1:9000 # uwsgi直接訪問用http,nginx訪問用socket http= 127.0.0.1:9000 chdir = /usr/local/www/項目目錄 wsgi-file = /usr/local/www/項目目錄/項目目錄/wsgi.py module = 項目目錄.wsgi

    2024年01月21日
    瀏覽(29)
  • Django筆記四十二之model使用validator驗證器

    Django筆記四十二之model使用validator驗證器

    本文首發(fā)于公眾號:Hunter后端 原文鏈接:Django筆記四十二之model使用validator驗證器 這一篇筆記介紹一下 model 里的 validator 驗證器。 首先,這是個什么東西呢? 在 model 的第四篇筆記里,我們介紹了字段的一些屬性,比如是否允許為空,varchar 類型的字段的最大長度等。 一般在

    2024年02月05日
    瀏覽(27)
  • 2-Docker-應(yīng)用-多容器部署Django+Vue項目(nginx+uwsgi+mysql)

    2-Docker-應(yīng)用-多容器部署Django+Vue項目(nginx+uwsgi+mysql)

    基于Linux CentOS 7系統(tǒng)(虛擬機),使用Docker,多容器部署Django+Vue項目 整體部署用到了:Django+Vue+nginx+mysql+uwsgi 先每一個容器單獨部署,最后用Docker compose 語法整合,統(tǒng)一部署 參考文章:https://blog.csdn.net/qq_45445505/article/details/135563784 章標(biāo)題:Docker介紹 節(jié)標(biāo)題:Docker安裝 總結(jié)梳

    2024年03月10日
    瀏覽(34)
  • linux+python3.6.8+uwsgi+postgresql+django部署web服務(wù)器

    linux+python3.6.8+uwsgi+postgresql+django部署web服務(wù)器

    我這是使用華為云服務(wù)器

    2024年02月06日
    瀏覽(51)
  • 【正點原子STM32連載】 第四十三章 SPI實驗 摘自【正點原子】APM32F407最小系統(tǒng)板使用指南

    【正點原子STM32連載】 第四十三章 SPI實驗 摘自【正點原子】APM32F407最小系統(tǒng)板使用指南

    1)實驗平臺:正點原子stm32f103戰(zhàn)艦開發(fā)板V4 2)平臺購買地址:https://detail.tmall.com/item.htm?id=609294757420 3)全套實驗源碼+手冊+視頻下載地址: http://www.openedv.com/thread-340252-1-1.html## 本章將介紹使用APM32F407驅(qū)動板載的NOR Flash進行讀寫操作。通過本章的學(xué)習(xí),讀者將學(xué)習(xí)到使用SPI驅(qū)

    2024年02月08日
    瀏覽(26)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包