django db 设置到一个带有解耦的 .env 文件中

问题描述

我想将我的 django 数据库设置放入 .env 文件中以进行生产。

虽然我在我的 .env 文件中成功写入了 SECRET KEYDEBUG,但当我尝试对我的数据库设置执行相同的操作时,我在 web 应用程序中遇到错误

这是我的做法:


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$

解决方法

您仍然需要将 DATABASES 设置定义为字典:

DATABASES = {
    'default': {
        'ENGINE': 'django_tenants.postgresql_backend','NAME': config('DATABASE_NAME'),'USER': config('DATABASE_USER'),'PASSWORD' : config('DATABASE_PASSWORD'),'HOST': config('DATABASE_HOST'),'PORT': config('DATABASE_PORT'),}
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...