ModuleNotFoundError:“没有名为 <mymodule> 的模块”,当从 Django 部署到 Heroku 时

时间:2021-05-14 01:49:22

标签: python django heroku modulenotfounderror

在将我的 Django 应用程序部署到 Heroku 时,我收到一个 ModuleNotFoundError,指出“没有名为‘RealisticEstate’的模块”。 RealisticEstate 是我的 Django 项目的名称。该程序构建没有问题,但是当我尝试部署时出现以下错误:

[2021-05-13 21:35:45 -0400] [15610] [INFO] Starting gunicorn 20.1.0
9:35:45 PM web.1 |  [2021-05-13 21:35:45 -0400] [15610] [INFO] Listening at: 
http://0.0.0.0:5000 (15610) 9:35:45 PM web.1 |  [2021-05-13 21:35:45 -0400] [15610] [INFO] Using worker: sync
9:35:45 PM web.1 |  [2021-05-13 21:35:45 -0400] [15613] [INFO] Booting worker with pid: 15613
9:35:45 PM web.1 |  [2021-05-13 21:35:45 -0400] [15613] [ERROR] Exception in worker process
9:35:45 PM web.1 |  Traceback (most recent call last):
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site- packages/gunicorn/arbiter.py", line 589, in spawn_worker
9:35:45 PM web.1 |      worker.init_process()
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/workers/base.py", line 134, in init_process
9:35:45 PM web.1 |      self.load_wsgi()
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/workers/base.py", line 146, in load_wsgi
9:35:45 PM web.1 |      self.wsgi = self.app.wsgi()
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/app/base.py", line 67, in wsgi
9:35:45 PM web.1 |      self.callable = self.load()
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/app/wsgiapp.py", line 58, in load
9:35:45 PM web.1 |      return self.load_wsgiapp()
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/app/wsgiapp.py", line 48, in load_wsgiapp
9:35:45 PM web.1 |      return util.import_app(self.app_uri)
9:35:45 PM web.1 |    File "/Users/<user>/RealisticEstate/venv/lib/python3.9/site-packages/gunicorn/util.py", line 359, in import_app
9:35:45 PM web.1 |      mod = importlib.import_module(module)
9:35:45 PM web.1 |    File "/usr/local/Cellar/python@3.9/3.9.5/Frameworks/Python.framework/Versions/3.9/lib/python3.9/importlib/__init__.py", line 127, in import_module
9:35:45 PM web.1 |      return _bootstrap._gcd_import(name[level:], package, level)
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 1030, in _gcd_import
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 1007, in _find_and_load
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 972, in _find_and_load_unlocked
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 228, in _call_with_frames_removed
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 1030, in _gcd_import
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 1007, in _find_and_load
9:35:45 PM web.1 |    File "<frozen importlib._bootstrap>", line 984, in _find_and_load_unlocked
9:35:45 PM web.1 |  ModuleNotFoundError: No module named 'RealisticEstate'

我的Procfile如下:

web: gunicorn RealisticEstate.wsgi

我的 Heroku 项目名为“realisticestate”,但是当我尝试将 Procfile 更改为:

web: gunicorn realisticestate.wsgi

它抛出同样的错误。

这是项目结构:

RealisticEstate
|___config
|   |___static
|   |   |___admin
|   |       |___css     
|   |       |___font
|   |       |___img
|   |       |___js
|   |___ __init__.py
|   |___ asgi.py
|   |___ settings.py
|   |___ urls.py
|   |___ wsgi.py
|
|___mapper
|   |___ migrations
|   |___ utils
|   |   |___ __init.py__
|   |   |___ update_db.py
|   |___ __init.py__
|   |___ admin.py
|   |___ apps.py
|   |___ forms.py
|   |___ models.py
|   |___ tests.py
|   |___ urls.py
|   |___ views.py
|   |___ staticfiles
|
|___ templates
|___ venv
|___ .gitignore
|___ manage.py
|___ models.py
|___ Procfile
|___ requirements.txt

任何帮助将不胜感激

2 个答案:

答案 0 :(得分:0)

只有 git 根目录 (RealisticEstate) 内的内容才会被推送到 Heroku,而不是目录本身。您的 wsgi 文件是 config/wsgi.py 因此您应该使用:

web: gunicorn config.wsgi

答案 1 :(得分:0)

确实需要将 project_name 放在 Procfile 中,因为包装所有文件夹的文件夹始终与 wsgi.py 所在的文件夹具有相同的名称。 >Procfile 应该指向,但在您的情况下,您将其命名为 config 所以它应该是:

web: gunicorn config.wsgi 

我个人是这样添加的:

web: gunicorn config.wsgi --log-file -