ModuleNotFound 错误尝试在 Heroku 中打开 Django 应用程序 - gunicorn 设置问题?

Posted

技术标签:

【中文标题】ModuleNotFound 错误尝试在 Heroku 中打开 Django 应用程序 - gunicorn 设置问题?【英文标题】:ModuleNotFound error trying to open Django app in Heroku- issue with gunicorn setup? 【发布时间】:2021-09-10 01:37:08 【问题描述】:

我一直在构建我的第一个 Django 项目(到目前为止,我只是使用 runserver 在本地运行它),我正在采取步骤将它托管在 Heroku 上,并添加 gunicorn。构建成功,但是当我尝试打开应用程序时,Heroku 日志显示工作进程中的异常

ModuleNotFoundError: No module named 'mysite.wsgi'

原来我的 Procfile 有这个:

web: gunicorn mysite.wsgi

当我在本地尝试那个 gunicorn 命令时,它会在 family-django/mysite 目录中工作,但是当我从根目录 (family-django) 尝试时,它会给我相同的“没有名为 mysite 的模块” .wsgi' 错误。根据this post,Heroku 会从根目录尝试,所以我更新了我的 Procfile 如下,告诉它从 mysite 目录运行:

web: gunicorn --chdir mysite mysite.wsgi

当从根目录 (family-django) 运行时,这个新的 gunicorn 命令在本地运行,万岁!那一定是我需要的修复。 但是:在 Heroku 中更新 Procfile 并尝试再次打开应用程序后,它仍然失败,上面粘贴了“没有名为 mysite.wsgi 的模块”错误。因此 Heroku 需要为此进行一些其他调整跑到那里去。

我的Django项目结构是这样的:

family-django
|-mysite 
| |-familytree
| |-myauth
| |-mysite
|   |-asgi.py
|   |-settings.py
|   |-urls.py
|   |-wsgi.py
|-Procfile
|-requirements.txt

wsgi.py 和 asgi.py 都是在项目开始时创建的。 (不确定两者兼有是否是错误的?)。 wsgi.py 有:

import os

from django.core.wsgi import get_wsgi_application

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'mysite.settings')

application = get_wsgi_application()

settings.py 包含 INSTALLED_APPS 和 WSGI_APPLICATION 的以下信息:

    INSTALLED_APPS = [
    'familytree.apps.FamilytreeConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.humanize',
    "myauth",
]

WSGI_APPLICATION = 'mysite.wsgi.application'

现在我想在 Heroku 上解决这个问题,他们推荐 gunicorn,所以我添加了一个 requirements.txt:

django
django-heroku
gunicorn

Procfile 有:

web: gunicorn --chdir mysite mysite.wsgi

【问题讨论】:

【参考方案1】:
#----------------------------Install packages---------------------------- 
 1)pip install django-heroku
 2)pip install whitenoise

#-----------------------------setting.py----------------------------------#
1)INSTALLED_APPS = [
...,
'django_heroku',
]

2)MIDDLEWARE = [
  'whitenoise.middleware.WhiteNoiseMiddleware',

 ]

3)STATICFILES_STORAGE = 
 'whitenoise.storage.CompressedManifestStaticFilesStorage'

4)STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
  STATIC_URL = '/static/'

# Extra places for collectstatic to find static files.
STATICFILES_DIRS = (
 os.path.join(BASE_DIR, 'static'),
)


django_heroku.settings(locals())

#-----------------------urls.py---------------------------------------#
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = [
 ...,
] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)

 #------------------Procfile create in Root DIR-----------------#
  paste in  (web: gunicorn projectname.wsgi)

 #--------------create requirements.txt---------------------------#

 pip freeze > requirements.txt

 # runtime.txt  create in Root DIR
 paste in (your python version for ex.python-3.8.5)

 #---------then commands in terminal-------------------------#

 heroku login
 heroku create YOUR_APP_NAME

 ##for Clone the repository.......
 git init
 heroku git:clone -a YOUR_APP_NAME

 ## for Deploy your changes......
 git init
 git add .
 git commit - m "initial"
 git push heroku master

 ## then

 heroku run python manage.py migrate
 heroku run python manage.py createsuperuser

【讨论】:

奇怪!是的,不同之处在于添加了白噪声!我没有意识到 Heroku 需要它来支持静态资产:devcenter.heroku.com/articles/django-assets 最初的错误消息不会让我想到朝那个方向前进,感谢您的推动!

以上是关于ModuleNotFound 错误尝试在 Heroku 中打开 Django 应用程序 - gunicorn 设置问题?的主要内容,如果未能解决你的问题,请参考以下文章

使用 conda 成功安装 cgal 后出现 ModuleNotFound 错误?

设置上的wxpython错误 - ModuleNotFound:没有名为'wx'的模块

React,Sass,从 .scss 文件导入 img 时出错

如何在 Flutter 中将 Hero 动画添加到我的 ListView?

未找到模块:错误:无法使用 Webpack 解析“fs”

错误 C2039:“向量”:不是“标准”的成员