django配置使用asgi的實(shí)現(xiàn)步驟
一、配置前提
Django 版本:確保使用 Django 3.0+(原生支持 ASGI)
必要依賴:
pip install daphne channels
二、基礎(chǔ)配置步驟
1. 創(chuàng)建/修改 ASGI 入口文件
在 Django 項(xiàng)目根目錄(與 settings.py
同級(jí))創(chuàng)建 asgi.py
:
import os from django.core.asgi import get_asgi_application from channels.routing import ProtocolTypeRouter os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'your_project.settings') # 基礎(chǔ)配置(無(wú)WebSocket需求) application = get_asgi_application() # 如果使用Channels(WebSocket支持) application = ProtocolTypeRouter({ "http": get_asgi_application(), "websocket": AuthMiddlewareStack( URLRouter( your_app.routing.websocket_urlpatterns ) ), })
2. 修改項(xiàng)目設(shè)置
settings.py
中添加:
# 配置ASGI應(yīng)用路徑 ASGI_APPLICATION = 'your_project.asgi.application' # 如果使用Channels需要添加 INSTALLED_APPS = [ ... 'channels', 'your_app', ] # 配置通道層(開(kāi)發(fā)環(huán)境使用內(nèi)存層) CHANNEL_LAYERS = { "default": { "BACKEND": "channels.layers.InMemoryChannelLayer" } }
3. 項(xiàng)目結(jié)構(gòu)驗(yàn)證
your_project/ ├── asgi.py # ASGI入口文件 ├── settings.py ├── urls.py └── your_app/ ├── routing.py # WebSocket路由配置(可選) ...
三、不同場(chǎng)景配置示例
場(chǎng)景1:純HTTP服務(wù)
# asgi.py import os from django.core.asgi import get_asgi_application os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'your_project.settings') application = get_asgi_application()
場(chǎng)景2:WebSocket服務(wù)
- 創(chuàng)建路由文件
your_app/routing.py
:
from django.urls import path from . import consumers websocket_urlpatterns = [ path('ws/chat/', consumers.ChatConsumer.as_asgi()), ]
- 修改
asgi.py
:
from channels.auth import AuthMiddlewareStack from channels.routing import ProtocolTypeRouter, URLRouter import your_app.routing application = ProtocolTypeRouter({ "http": get_asgi_application(), "websocket": AuthMiddlewareStack( URLRouter( your_app.routing.websocket_urlpatterns ) ), })
四、運(yùn)行與驗(yàn)證
1. 使用 Daphne 啟動(dòng)
daphne -b 0.0.0.0 -p 8000 your_project.asgi:application
2. 生產(chǎn)環(huán)境部署(Nginx + Daphne)
示例 Nginx 配置:
location / { proxy_pass http://127.0.0.1:8000; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_redirect off; }
3. 測(cè)試命令
# 測(cè)試HTTP curl http://localhost:8000 # 測(cè)試WebSocket(使用wscat) wscat -c ws://localhost:8000/ws/chat/
五、常見(jiàn)問(wèn)題解決
錯(cuò)誤1:You have not set ASGI_APPLICATION
• 確保 settings.py
中正確配置:
ASGI_APPLICATION = 'your_project.asgi.application'
錯(cuò)誤2:Requested setting INSTALLED_APPS...
• 檢查 DJANGO_SETTINGS_MODULE
環(huán)境變量是否正確設(shè)置
錯(cuò)誤3:WebSocket連接失敗
• 驗(yàn)證 CHANNEL_LAYERS
配置
• 檢查Nginx是否配置了WebSocket代理
六、高級(jí)配置
1. 使用Redis通道層(生產(chǎn)環(huán)境)
CHANNEL_LAYERS = { "default": { "BACKEND": "channels_redis.core.RedisChannelLayer", "CONFIG": { "hosts": [("redis-server", 6379)], }, } }
七、關(guān)鍵注意事項(xiàng)
- 開(kāi)發(fā)/生產(chǎn)環(huán)境區(qū)分:通道層配置需要根據(jù)環(huán)境變化
- 性能監(jiān)控:使用
daphne
的--verbosity
參數(shù)調(diào)試 - 版本兼容性:
• Django 3.0+ 原生支持 ASGI
• Channels 3.0+ 需要 Python 3.6+
通過(guò)以上配置,Django 項(xiàng)目即可完整支持 ASGI 協(xié)議,既能處理傳統(tǒng)HTTP請(qǐng)求,也能支持實(shí)時(shí)WebSocket通信。
八 編寫(xiě)start.py啟動(dòng)django+asgi
import os from daphne.cli import CommandLineInterface import django import subprocess import sys def main(): base_path = os.path.dirname(os.path.abspath(__file__)) # print("#"*30) # print(base_path) chat_ai_path = os.path.join(base_path, 'xxx') sys.path.append(chat_ai_path) sys.path.append(base_path) # 設(shè)置默認(rèn)的 Django 設(shè)置模塊 os.environ.setdefault("DJANGO_SETTINGS_MODULE", 'xxx') # 替換為您的項(xiàng)目名稱 django.setup() # 配置 Daphne 的運(yùn)行參數(shù) sys.argv = [ # "daphne", "-b", "0.0.0.0", "-p", "8000", "xxx.asgi:application" ] CommandLineInterface().run(sys.argv) if __name__ == "__main__": main()
到此這篇關(guān)于django配置使用asgi的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)django配置使用asgi內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python語(yǔ)言的12個(gè)基礎(chǔ)知識(shí)點(diǎn)小結(jié)
這篇文章主要介紹了Python語(yǔ)言的12個(gè)基礎(chǔ)知識(shí)點(diǎn)小結(jié),包含正則表達(dá)式替換、遍歷目錄方法、列表按列排序、去重、字典排序等,需要的朋友可以參考下2014-07-07Python復(fù)制Excel表格中指定數(shù)據(jù)若干次的方法
本文介紹基于Python語(yǔ)言,讀取Excel表格文件數(shù)據(jù),并基于其中某一列數(shù)據(jù)的值,將這一數(shù)據(jù)處于指定范圍的那一行加以復(fù)制,并將所得結(jié)果保存為新的Excel表格文件的方法,需要的朋友可以參考下2024-02-02Python中的enumerate() 函數(shù)用法詳解
enumerate()是python的內(nèi)置函數(shù),將一個(gè)可遍歷iterable數(shù)據(jù)對(duì)象(如list列表、tuple元組或str字符串)組合為一個(gè)索引序列,同時(shí)列出數(shù)據(jù)和數(shù)據(jù)下標(biāo),一般用在for循環(huán)當(dāng)中,這篇文章主要介紹了Python中的enumerate() 函數(shù)用法詳解,需要的朋友可以參考下2024-01-01Python的自動(dòng)化部署模塊Fabric的安裝及使用指南
這篇文章主要介紹了Python的自動(dòng)化部署模塊Fabric的安裝及使用指南,文中以Debian系統(tǒng)為環(huán)境進(jìn)行了實(shí)例演示,需要的朋友可以參考下2016-01-01詳解pyppeteer(python版puppeteer)基本使用
這篇文章主要介紹了詳解pyppeteer(python版puppeteer)基本使用 ,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Python Web程序部署到Ubuntu服務(wù)器上的方法
在本文記錄了我在Ubuntu中部署Flask Web站點(diǎn)的過(guò)程, 其中包括用戶創(chuàng)建、代碼獲取、Python3環(huán)境的安裝、虛擬環(huán)境設(shè)置、uWSGI啟動(dòng)程序設(shè)置,并將Nginx作為前端反向代理,需要的朋友參考下吧2018-02-02