我想将我的 django 数据库设置放入 .env 文件中进行生产。
虽然我成功编写SECRET KEY
并DEBUG
在我的 .env 文件中,但当我尝试对我的数据库设置做同样的事情时,我在 webapp 中得到一个错误。
这是我的做法:
SECRET_KEY = config('SECRET_KEY')
DEBUG = config('DEBUG', default=False, cast=bool)
DATABASE_ENGINE ='django_tenants.postgresql_backend'
DATABASE_NAME = config('DATABASE_NAME')
DATABASE_USER = config('DATABASE_USER')
DATABASE_PASSWORD = config('DATABASE_PASSWORD')
DATABASE_HOST = config('DATABASE_HOST', cast=db_url)
DATABASE_PORT = config('PORT', cast=int)
在我的 .env 文件中
SECRET_KEY = supersecretkey
DEBUG = False
DATABASE_NAME = mydb
DATABASE_USER = me
DATABASE_PASSWORD = greatpassword
DATABASE_HOST =urlurl
DATABASE_PORT = 5432
以前我的数据库设置是这样写的,一切都很好:
DATABASES = {
'default': {
'ENGINE': 'django_tenants.postgresql_backend',
'NAME': 'mydb',
'USER': 'me',
'PASSWORD' : 'greatpassword',
'HOST': 'urlurl',
'PORT': '5432',
}
}
更新:由于评论,我在 settings.py 中尝试了以下结构,但仍然得到相同的错误:
DATABASES = {
'default': {
'ENGINE': 'django_tenants.postgresql_backend',
'NAME': config('DATABASE_NAME'),
'USER': config('DATABASE_USER'),
'PASSWORD' : config('DATABASE_PASSWORD'),
'HOST': 'config('DATABASE_HOST', cast=db_url),
'PORT': config('DATABASE_PORT'),
}
}
Django 的日志正在输出这个,但我看不出它与手头的问题有什么关系:
Traceback (most recent call last):
File "/home/ubuntu/exo/lib/python3.6/site-packages/django/template/base.py", line 850, in _resolve_lookup
(bit, current)) # missing attribute
django.template.base.VariableDoesNotExist: Failed lookup for key [redirect_to] in [{'True': True, 'False': False, 'None': None}, {'csrf_token': <SimpleLazyObject: '3UKtg6BF5E1qXSTE8nlEevd4e4jVZMcgpdx5W0NZIrB18yuOoCJqnW7xxc7WBfyG'>, 'request': <WSGIRequest: GET '/'>, 'user': <SimpleLazyObject: <function AuthenticationMiddleware.process_request.<locals>.<lambda> at 0x7fa6a25$