Heroku数据库设置注入 - 如何设置我的dev django数据库?

hei*_*etz 30 django heroku

在按照添加env数据库设置的这些说明后,我正在尝试让我的本地dev django应用程序工作.

https://devcenter.heroku.com/articles/django-injection

我按照说明操作,但在我的应用程序尝试访问本地数据库时出现以下错误

Request Method: GET
Request URL:    http://localhost:8000
Django Version: 1.4
Exception Type: ImproperlyConfigured
Exception Value:    
You need to specify NAME in your Django settings file.
Run Code Online (Sandbox Code Playgroud)

我最初的数据库设置,

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'db',                      # Or path to database file if using sqlite3.
        'USER': 'foo',                      # Not used with sqlite3.
        'PASSWORD': 'bar',                  # Not used with sqlite3.
        'HOST': 'localhost',                
        'PORT': '5432',
    }
}
Run Code Online (Sandbox Code Playgroud)

heroku文章说要将以下内容添加到设置文件中

import dj_database_url
DATABASES = {'default': dj_database_url.config(default='postgres://localhost')}
Run Code Online (Sandbox Code Playgroud)

当DATABASE_URL在dev中不可用时,如何让dj_database_url.config使用我的开发设置?

小智 39

您可以将您的开发设置添加到默认值,如下所示...

import dj_database_url
DATABASES = {'default': dj_database_url.config(default='postgres://foo:bar@localhost:5432/db')}
Run Code Online (Sandbox Code Playgroud)


小智 13

在settings.py中使用它:

DATABASES = {'default': dj_database_url.config(default=os.environ['DATABASE_URL'])}
Run Code Online (Sandbox Code Playgroud)

并在.env文件中有这个:

DATABASE_URL=postgres://localhost/yourdbname
Run Code Online (Sandbox Code Playgroud)

当您使用"foreman start"启动时,它将查看.env文件并创建所有这些环境变量,就像在Heroku上运行一样.键入"heroku config"以确认您已设置DATABASE_URL,如果添加了postgres数据库插件,则应该这样做.

  • 将'default'分配给DATABASE_URL是多余的,DATABASE_URL是config()默认读取的环境变量. (2认同)

ldi*_*ual 8

只需在您的操作系统上设置一个环境变量,并检查它们是否已设置.例如,使用UNIX系统:

# In ~/.bash_profile
export LOCAL_DEV=true

# In settings.py
import dj_database_url
DATABASES = {'default': dj_database_url.config(default='postgres://localhost')}

if bool(os.environ.get('LOCAL_DEV', False)):
    # Override DATABASES['default'] with your local database configuration
Run Code Online (Sandbox Code Playgroud)

此外,如果您需要在heroku空间上设置环境变量:

heroku config:add MY_VAR='my_value'
Run Code Online (Sandbox Code Playgroud)

  • 实际上正确的语法是`heroku config:add MY_VAR ='my_value'` (2认同)

min*_*nel 5

我刚试过这个,这是我的代码:

import dj_database_url

local_db = 'postgres://django_login:123456@localhost/django_db'
DATABASES = {'default': dj_database_url.config(default=local_db)}
Run Code Online (Sandbox Code Playgroud)

我的数据库名称是"django_db",用户名是"django_login",密码是"123456".

我的代码可以在本地机器和heroku中运行.