在執行數據庫遷移的時候報出錯誤RuntimeError: populate() isn't reentrant,之前也出過這個錯誤,但是忘記記錄了,這次又出現了。百度搜好好多,都沒解決我的問題,這里做個踩坑記錄。
背景:項目有多個app,現在新需求增加了一個app,並編寫了該app的utils文件
在執行python manage.py makemigrations后報出如下異常
Traceback (most recent call last):
File "manage.py", line 14, in <module>
execute_from_command_line(sys.argv)
File "D:\Program Files\Python37\lib\site-packages\django\core\management\__init__.py", line 381, in execute_from_command_line
utility.execute()
File "D:\Program Files\Python37\lib\site-packages\django\core\management\__init__.py", line 357, in execute
django.setup()
File "D:\Program Files\Python37\lib\site-packages\django\__init__.py", line 24, in setup
apps.populate(settings.INSTALLED_APPS)
File "D:\Program Files\Python37\lib\site-packages\django\apps\registry.py", line 81, in populate
raise RuntimeError("populate() isn't reentrant")
RuntimeError: populate() isn't reentrant
跟着錯誤信息,初步判定是新創建的app才引發的此問題,所以就把INSTALLED_APPS中新創建的app注釋掉,再執行python manage.py makemigrations就不報異常了。
所以錯誤信息應當在新app中,在檢查到utils文件時,發現引入包的方式有問題
文件目錄為
未修改時引入方式為
修改后方式為
就是在引入TLSSigAPI模塊時加上app的名稱
總結:在新建app並初始化后,如果提示RuntimeError: populate() isn't reentrant錯誤,應該先檢查每個app的模塊引入情況。