python3.7環(huán)境下sanic-ext未生效踩坑解析
坑:
在python3.7環(huán)境下,通過官方文檔安裝sanic即擴展插件,但是 sanic-ext包不起作用,具體的表現(xiàn)為:無法打開路由/docs。
這里的坑在于,服務(wù)啟動時,sanic不會報錯。因此很難定位出問題在sanic-ext。
原因:
尋找sanic-ext不起作用的原因:
首先在虛擬環(huán)境中執(zhí)行import sanic_ext
結(jié)果報錯,提示缺少importlib.metadata
查詢當前環(huán)境下importlib.metadata的版本,發(fā)現(xiàn)在python3.7下importlib.metadata=4.2
由于本人曾在python3.8環(huán)境可以正常使用sanic-ext,所以進入python3.8環(huán)境下檢查發(fā)現(xiàn)importlib.metadata=3.10.0
結(jié)論:
python3.7下的importlib.metadata版本與sanic-ext不匹配,導致其無法起作用
回過頭看:
雖然sanic-ext不會報錯,但其實sanic-ext是否生效是有跡可循的,在sanic啟動時,會有一串打印信息,可以通過打印信息中的packages中是否包含sanic-ext判斷sanic-ext是否正確生效。
┌─────────────────────────────────────────────────────────────────────────────────────────────────────────┐ │ Sanic v22.9.0 │ │ Goin' Fast @ http://0.0.0.0:12345 │ ├───────────────────────┬─────────────────────────────────────────────────────────────────────────────────┤ │ │ mode: debug, single worker │ │ ▄███ █████ ██ │ server: sanic, HTTP/1.1 │ │ ██ │ python: 3.8.8 │ │ ?███████ ███▄ │ platform: Linux-4.15.0-189-generic-x86_64-with-glibc2.10 │ │ ██ │ auto-reload: enabled, /xx/xx/xx │ │ ████ ████████? │ packages: sanic-routing==22.8.0, sanic-ext==22.9.0 │ │ │ │ │ Build Fast. Run Fast. │ │
后記
python3.7的importlib.metadata高于python3.8的,不符合直覺,可能是裝其他東西更新了這個包,所以也許不是python3.7與sanic-ext不適配,這點有待繼續(xù)驗證,更多關(guān)于python3.7環(huán)境sanic-ext未生效的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python實現(xiàn)腳本轉(zhuǎn)換為命令行程序
使用Python中的scaffold和click庫,你可以將一個簡單的實用程序升級為一個成熟的命令行界面工具,本文就來帶你看看具體實現(xiàn)方法,感興趣的可以了解下2022-09-09
Python判斷一個三位數(shù)是否為水仙花數(shù)的示例
今天小編就為大家分享一篇Python判斷一個三位數(shù)是否為水仙花數(shù)的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11
pytorch模型保存與加載中的一些問題實戰(zhàn)記錄
一般來說,保存模型是把參數(shù)全部用model.cpu().state_dict(),然后加載模型時一般用model.load_state_dict(torch.load(model_path)),下面這篇文章主要給大家介紹了關(guān)于pytorch模型保存與加載中的一些問題實戰(zhàn)記錄,需要的朋友可以參考下2022-10-10

