django.core.exceptions.AppRegistryNotReady:应用程序不可用;我还没上膛。(django 2.0.1)(Python 3.6)
这是我第一次尝试将Django应用程序(Django 2.0.1)(Python3.6)部署到Pythonywhere,它是一个简单的组合应用程序,没有模型,没有引导。 只有Django、HTML、CSS和Javascript 在使用bash控制台将它从Github repo拉到Pythnywhere之后,我运行:django.core.exceptions.AppRegistryNotReady:应用程序不可用;我还没上膛。(django 2.0.1)(Python 3.6),python,django,python-3.x,pythonanywhere,django-2.0,Python,Django,Python 3.x,Pythonanywhere,Django 2.0,这是我第一次尝试将Django应用程序(Django 2.0.1)(Python3.6)部署到Pythonywhere,它是一个简单的组合应用程序,没有模型,没有引导。 只有Django、HTML、CSS和Javascript 在使用bash控制台将它从Github repo拉到Pythnywhere之后,我运行: python manage.py migrate &被此错误击中: Traceback (most recent call last): File "manage.py", lin
python manage.py migrate
&被此错误击中:
Traceback (most recent call last):
File "manage.py", line 22, in <module>
execute_from_command_line(sys.argv)
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/core/management/__init__.py", line 371, in
execute_from_command_line
utility.execute()
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/core/management/__init__.py", line 365, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/core/management/__init__.py", line 216, in fetch_command
klass = load_command_class(app_name, subcommand)
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/core/management/__init__.py", line 36, in load_command_class
module = import_module('%s.management.commands.%s' % (app_name, name))
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/importlib/__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 978, in _gcd_import
File "<frozen importlib._bootstrap>", line 961, in _find_and_load
File "<frozen importlib._bootstrap>", line 950, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 655, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 205, in _call_with_frames_removed
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/core/management/commands/migrate.py", line 12, in <module>
from django.db.migrations.autodetector import MigrationAutodetector
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/db/migrations/autodetector.py", line 11, in <module>
from django.db.migrations.questioner import MigrationQuestioner
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-
packages/django/db/migrations/questioner.py", line 9, in <module>
from .loader import MigrationLoader
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/db/migrations/loader.py", line 8, in <module>
from django.db.migrations.recorder import MigrationRecorder
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/db/migrations/recorder.py", line 9, in <module>
class MigrationRecorder:
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/db/migrations/recorder.py", line 22, in MigrationRecorder
class Migration(models.Model):
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/db/models/base.py", line 100, in __new__
app_config = apps.get_containing_app_config(module)
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/apps/registry.py", line 244, in get_containing_app_config
self.check_apps_ready()
File "/home/Limerin555/.virtualenvs/projectenv/lib/python3.6/site-packages/django/apps/registry.py", line 127, in check_apps_ready
raise AppRegistryNotReady("Apps aren't loaded yet.")
django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet.
在这条线下面:
SECRET_KEY = os.environ.get("SECRET_KEY")
正如我的建议,但没有用
这是我的settings.py:
import django
django.setup()
import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
TEMPLATE_DIR = os.path.join(BASE_DIR, "templates")
STATIC_DIR = os.path.join(BASE_DIR, "static")
SECRET_KEY = os.environ.get('SECRET_KEY')
import django
django.setup()
DEBUG = False
ALLOWED_HOSTS = ["limerin555.pythonanywhere.com"]
INSTALLED_APPS = [
'django.contrib.contenttypes',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'portfolio_showcase',
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'limerin.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [TEMPLATE_DIR,],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'limerin.wsgi.application'
DATABASE_PATH = os.path.join(BASE_DIR, 'db.sqlite3')
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': DATABASE_PATH,
}
}
AUTH_PASSWORD_VALIDATORS = [
{
'NAME':
'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME':
'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME':
'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME':
'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'Asia/Singapore'
USE_I18N = True
USE_L10N = True
USE_TZ = True
STATIC_URL = '/static/'
STATICFILES_DIRS = [
STATIC_DIR,
]
我真的很迷茫,希望有人能帮我弄清楚真正的问题是什么。Django文档说,Django.setup第一步从settings.py加载设置,所以在settings.py中运行它似乎不是个好主意 尝试在已安装的应用程序中一次评论一个应用程序-您可能会发现其中一个应用程序由于某种原因未加载。一旦您知道它是哪一个,您就可以找出它的错误。请运行以查看它是否检测到任何错误
python manage.py check
和/或
django-admin check
刚刚克服了类似的情况 您真正需要的是:
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "your_project.settings")
然后这些线:
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
之后,您可以轻松导入模型,而无需AppRegistryNotReady:应用程序尚未加载。
更新:这实际上就是项目文件夹中wsgi.py文件中的4行代码
适用于DJANGO 3.0
在Django 3+中,需要一个额外的变量来解决同步/异步混淆:
os.environ["DJANGO_ALLOW_ASYNC_UNSAFE"] = "true"
此错误可能有多种原因,但所有原因都与
project/settings.py
文件有关
密钥
已安装的应用程序中安装了应用程序,但尚未安装
我花了一段时间才明白,每次运行
manage.py somecommand
,都需要提供运行/manage.py runserver
时所需的相同设置/环境变量
例如,我从名为.env
的文件中的环境变量加载SECRET\u KEY。因此,为了进行和运行迁移,我需要这样做:
. .env
./manage.py makemigrations --settings=djangoproject.settings.development
./manage.py migrate --settings=djangoproject.settings.development
我的问题是,我试图在运行安装程序之前导入。以下是我的解决方案:在安装后进行导入:
import django
# some variable declarations
world_mapping = {
'osm_id': 'osm_id',
}
if __name__ == '__main__':
django.setup()
# import AFTER setup
from app.models import WorldBorder
# from now I can access WorldBorder!!
首先检查您的project.wsgi.py中是否有与下面相同的代码
"""
WSGI config for store project.
It exposes the WSGI callable as a module-level variable named ``application``.
For more information on this file, see
https://docs.djangoproject.com/en/2.0/howto/deployment/wsgi/
"""
import os
from django.core.wsgi import get_wsgi_application
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "store.settings")
application = get_wsgi_application()
如前所述,此配置适用于django2.0,请尝试
您的版本的rigth代码
然后
在~/.basrc或~/.zshrc for zsh中键入以下代码,无论如何,在rigth shell文件中键入此代码
export SECRET_KEY="type_a_long_random_char_printable_here"
#like this: export SECRET_KEY="hjfhskjh(@/;,?jhod=sjhGJKghgjGHJh#=}"
我在heroku上部署django时遇到过这样的情况,经过反复检查后,再次检查了您的SECRET\u KEY=“在此处删除所有字符,如:$\`”,并且您没有指定任何不存在的目录。只需在
ready()内导入即可。
方法:
def ready(self):
print('Sent From ready')
from django.db.models.signals import post_save
from yourapp.api.signals import post_save_user_receiver
post_save.connect(post_save_user_receiver, sender=settings.AUTH_USER_MODEL)
在我的例子中,是应用程序中缺少的python包导致了问题 因此,请检查是否所有正在使用的应用程序/软件包都有效地安装在python(虚拟)环境中 可以在已安装的应用程序中找到的应用程序(请参阅settings.py文件)
Python包可以在代码中的任何地方使用,因此更难跟踪。但通常错误消息也会提示丢失的软件包。以防万一:我的问题是,我正在将一些类、函数和变量导入应用程序文件夹的
\uuuu init\uuu
文件中
在我清空
\uuuu init\uuuuu
文件后,它会按预期工作。您的公文包\u showcase
应用程序或根url配置中可能存在导致此问题的内容。不要将django.setup()
添加到设置中。我也遇到了同样的问题-我的问题是一个未设置的环境变量-使用带有django环境的postgresql,并且没有设置数据库URL-设置为我解决了这个问题。我在过去看到过这个错误。IIRC它必须处理依赖于第三方模块迁移的迁移文件。我没有正确定义迁移依赖项。在我的例子中,它是一个空的SECRET_KEY
env variable对于一个不存在的SECRET KEY来说是一个非常没有帮助的消息。如果python manage.py check运行正常,我们该怎么办,但是django admin check抱怨一些常量没有设置,比如说use18n?在我的情况下,最后两行就足够了。我将它们添加到我的projectname/projectname/\uuuu init\uuuuuuuuuuuuuuuuuuupy
中,因此它们总是在我的应用程序中执行之前执行。因为这4行对应于wsgi.py
文件内容(如答案中所述),您还可以在任何独立的python文件中执行导入_project.wsgi.py
,以启动django模块。(例如,用于尝试代码片段)这刚刚结束了两个小时的挫折。非常感谢,这可能是一个愚蠢的问题,但是我需要把代码放在哪里呢?这是一个关于如何导入django配置并使用它的示例。因此,您可以在自己的python文件中使用这段代码,例如,如果您需要运行自己的测试或制作一小段“一次性”代码(导入一些东西或其他东西)