在Django的View中使用asyncio的方法
起步
Django 是個(gè)同步框架,本文并不是 讓 Django 變成異步框架。而是對于在一個(gè) view 中需要請求多次 http api 的場景。
一個(gè)簡單的例子
例子來源于 https://stackoverflow.com/questions/44667242/python-asyncio-in-django-view :
def djangoview(request, language1, language2): async def main(language1, language2): loop = asyncio.get_event_loop() r = sr.Recognizer() with sr.AudioFile(path.join(os.getcwd(), "audio.wav")) as source: audio = r.record(source) def reco_ibm(lang): return(r.recognize_ibm(audio, key, secret language=lang, show_all=True)) future1 = loop.run_in_executor(None, reco_ibm, str(language1)) future2 = loop.run_in_executor(None, reco_ibm, str(language2)) response1 = await future1 response2 = await future2 loop = asyncio.new_event_loop() asyncio.set_event_loop(loop) loop = asyncio.get_event_loop() loop.run_until_complete(main(language1, language2)) loop.close() return(HttpResponse)
這個(gè)例子中,把兩個(gè)任務(wù)放到 asyncio 的 loop 運(yùn)行,等到兩個(gè)任務(wù)都完成了再返回 HttpResponse 。
在 Django 的 View 中使用 asyncio
現(xiàn)在可以對于上面的例子做一個(gè)擴(kuò)充,讓它能更合理被使用。
對于使用 asyncio ,我們通常會(huì)創(chuàng)建個(gè)子線程專門處理異步任務(wù)。
在 wsgi.py 中創(chuàng)建一個(gè)單獨(dú)線程并運(yùn)行事件循環(huán):
import asyncio import threading ... application = get_wsgi_application() # 創(chuàng)建子線程并等待 thread_loop = asyncio.new_event_loop() def start_loop(loop): asyncio.set_event_loop(loop) loop.run_forever() t = threading.Thread(target=start_loop, args=(thread_loop,), daemon=True) t.start()
然后就是在 view 中動(dòng)態(tài)向里面添加任務(wù)了:
async def fetch(url):
async with aiohttp.ClientSession() as session:
async with session.get(url) as response:
text = await response.text()
return text
def hello(request):
from yeezy_bot.wsgi import thread_loop
fut1 = asyncio.run_coroutine_threadsafe(fetch(url1), thread_loop)
fut2 = asyncio.run_coroutine_threadsafe(fetch(url2), thread_loop)
ret1 = fut1.result()
ret2 = fut2.result()
return HttpResponse('')
asyncio.run_coroutine_threadsafe() 返回是 Future 對象,因此可以通過 fut.result() 獲得任務(wù)的運(yùn)行結(jié)果。 這個(gè)方式也可以處理API請求中的數(shù)據(jù)依賴的先后順序。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解多線程Django程序耗盡數(shù)據(jù)庫連接的問題
- Django生成數(shù)據(jù)庫及添加用戶報(bào)錯(cuò)解決方案
- python自動(dòng)化測試三部曲之request+django實(shí)現(xiàn)接口測試
- 社區(qū)版pycharm創(chuàng)建django項(xiàng)目的方法(pycharm的newproject左側(cè)沒有項(xiàng)目選項(xiàng))
- Django連接本地mysql數(shù)據(jù)庫(pycharm)的步驟
- 記一次Django響應(yīng)超慢的解決過程
- Django實(shí)現(xiàn)文章詳情頁面跳轉(zhuǎn)代碼實(shí)例
- Django如何使用asyncio協(xié)程和ThreadPoolExecutor多線程
相關(guān)文章
pandas.DataFrame 根據(jù)條件新建列并賦值的方法
下面小編就為大家分享一篇pandas.DataFrame 根據(jù)條件新建列并賦值的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04
Python3.5 Pandas模塊缺失值處理和層次索引實(shí)例詳解
這篇文章主要介紹了Python3.5 Pandas模塊缺失值處理和層次索引,結(jié)合實(shí)例形式詳細(xì)分析了Python3.5 Pandas模塊缺失值處理和層次索引的原理、處理方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-04-04
Pandas 稀疏數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)
如果數(shù)據(jù)中有很多NaN的值,存儲(chǔ)起來就會(huì)浪費(fèi)空間。為了解決這個(gè)問題,Pandas引入了一種叫做Sparse data的結(jié)構(gòu),來有效的存儲(chǔ)這些NaN的值,本文就來詳細(xì)的介紹了一下,感興趣的可以了解一下2021-07-07
Python實(shí)現(xiàn)棧和隊(duì)列的簡單操作方法示例
這篇文章主要介紹了Python實(shí)現(xiàn)棧和隊(duì)列的簡單操作方法,結(jié)合實(shí)例形式詳細(xì)分析了Python棧和隊(duì)列的原理與簡單實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-11-11
PyTorch中model.zero_grad()和optimizer.zero_grad()用法
這篇文章主要介紹了PyTorch中model.zero_grad()和optimizer.zero_grad()用法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06

