やりたいこと
Djangoで時間がかかる処理のリクエストがきた場合に、非同期処理を使用して処理の完了を待たずにレスポンスを返したいと思いました。
Django2.2を使用していましたが、Django3xでは非同期Viewに対応しているとのことなのでこのサイトを参考にして作ってみました。
urls.py
に/app/test
でviews.py
のtest関数が実行されるようになっています。
test.txt
への書き込みに20秒かかるとして、下記のように書きました。
views.py
1async def save(): 2 await asyncio.sleep(0.5) # 質問部分 3 with open('app/test.txt', encoding='utf-8', mode='w') as f: 4 print('書き込みを開始します') 5 times = 20 6 for i in range(times): 7 # プログレスバー 8 prog = 50*(i+1)//times 9 progress_bar = '#'*(prog) + ' '*(50-prog) 10 print("\r", f"[{progress_bar}] {i+1}", end="") 11 sleep(1) 12 f.write('test test') 13 print('\n書き込みを終了します') 14 f.close() 15 16 17async def test(request): 18 loop = asyncio.get_event_loop() 19 # loop.create_task(http_call_async()) 20 loop.create_task(save()) 21 context = { 22 'object': 'test' 23 } 24 print('start render') 25 return render(request, 'app/test.html', context) 26
質問内容
save関数にawaitを書かないと非同期処理にならない
上のコードで最初はawait asyncio.sleep(0.5)
を書かずに実行していました。
すると、非同期処理にならずに、約20秒ほど待ってsave関数の処理が終わってからレスポンスが帰ってくるようになりました。
なぜ、await asyncio.sleep(0.5)
を書かないと非同期処理にならないのでしょうか
await asyncio.sleep(0.5)
をすることでCPUの空きが発生しそれを使用して他の処理を実行するようになるからで、これを書かないと他の処理が入るきっかけができない、という認識であっているのでしょうか。
補足情報(FW/ツールのバージョンなど)
MacOS
Djnaog==3.2
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。