前提・実現したいこと
作成したDjangoのアプリをherokuにデプロイしたのですが、migrate
すると、以下のようなエラーが出ます。
このエラーを解決したいです。
追加の質問
- settings.pyに書くdbの
name
やuser
などは、ローカルにあるpostgresql
の名前やユーザー名で良いのでしょうか? - それとも、heroku側に作り出した、
Postgresql
の名前やユーザ名になるのでしょうか? - その場合は、heroku側の
postgresql
のユーザ名やパスワードを取得する方法を教えていただけるとありがたいです。 - 開発用(settings_dev.py)、本番用、共通用(settings_common.py)にsettings.pyを同じDjangoプロジェクトの下に作りまして、共通用と開発用は
.gitignore
するのですが、その書き方は、以下の形で良いのでしょうか?
Django
1deploy_project/settings_dev.py 2deploy_project/settings_common.py
発生している問題・エラーメッセージ
Is the server running on host "localhost" (127.0.0.1) and accepting TCP/IP connections on port 5432?
該当のソースコード
Django
1DATABASES = { 2 'default': { 3 'ENGINE': 'django.db.backends.postgresql_psycopg2', 4 'NAME': 'my_database', 5 'USER': os.environ.get('DB_USER'), 6 'PASSWORD': os.environ.get('DB_PASSWORD'), 7 'HOST': 'localhost', 8 'PORT': '5432' 9 } 10}
試したこと
以下のようにした後、デプロイしたとしてもmigrateをすると同じエラーが出ます。
Django
1import dj_database_url 2DATABASES['default'] = dj_database_url.config() 3SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
また、dbのUser
とPASSWORD
を直書きしても、上手くいきませんでした。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
前提・実現したいこと
作成したDjangoのアプリをherokuにデプロイしたのですが、migrate
すると、以下のようなエラーが出ます。
このエラーを解決したいです。
追加の質問
- settings.pyに書くdbの
name
やuser
などは、ローカルにあるpostgresql
の名前やユーザー名で良いのでしょうか? - それとも、heroku側に作り出した、
Postgreql
の名前やユーザ名になるのでしょうか? - その場合は、heroku側の
postgresql
のユーザ名やパスワードを取得する方法を教えていただけるとありがたいです。
発生している問題・エラーメッセージ
Is the server running on host "localhost" (127.0.0.1) and accepting TCP/IP connections on port 5432?
該当のソースコード
settings.py
Django
1DATABASES = { 2 'default': { 3 'ENGINE': 'django.db.backends.postgresql_psycopg2', 4 'NAME': 'my_database', 5 'USER': os.environ.get('DB_USER'), 6 'PASSWORD': os.environ.get('DB_PASSWORD'), 7 'HOST': 'localhost', 8 'PORT': '5432' 9 } 10}
また、settings.pyの全体のコードも一応載せておきます。
Django
1import os 2from django.contrib.messages import constants as messages 3import dj_database_url 4 5# Build paths inside the project like this: os.path.join(BASE_DIR, ...) 6BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) 7 8DEBUG = False 9 10ALLOWED_HOSTS = ['*'] 11 12MEDIA_ROOT = os.path.join(BASE_DIR, 'media') 13 14EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend' 15 16# Quick-start development settings - unsuitable for production 17# See https://docs.djangoproject.com/en/3.0/howto/deployment/checklist/ 18 19# Application definition 20 21INSTALLED_APPS = [ 22 'django.contrib.admin', 23 'django.contrib.auth', 24 'django.contrib.contenttypes', 25 'django.contrib.sessions', 26 'django.contrib.messages', 27 'django.contrib.staticfiles', 28 'deploy_app', 29 'accounts', 30 'django.contrib.sites', 31 'allauth', 32 'allauth.account', 33] 34 35MIDDLEWARE = [ 36 'django.middleware.security.SecurityMiddleware', 37 'whitenoise.middleware.WhiteNoiseMiddleware', 38 'django.contrib.sessions.middleware.SessionMiddleware', 39 'django.middleware.common.CommonMiddleware', 40 'django.middleware.csrf.CsrfViewMiddleware', 41 'django.contrib.auth.middleware.AuthenticationMiddleware', 42 'django.contrib.messages.middleware.MessageMiddleware', 43 'django.middleware.clickjacking.XFrameOptionsMiddleware', 44] 45 46ROOT_URLCONF = 'deploy_project.urls' 47 48TEMPLATES = [ 49 { 50 'BACKEND': 'django.template.backends.django.DjangoTemplates', 51 'DIRS': [], 52 'APP_DIRS': True, 53 'OPTIONS': { 54 'context_processors': [ 55 'django.template.context_processors.debug', 56 'django.template.context_processors.request', 57 'django.contrib.auth.context_processors.auth', 58 'django.contrib.messages.context_processors.messages', 59 ], 60 }, 61 }, 62] 63 64WSGI_APPLICATION = 'deploy_project.wsgi.application' 65 66 67# Database 68# https://docs.djangoproject.com/en/3.0/ref/settings/#databases 69 70DATABASES = { 71 'default': { 72 'ENGINE': 'django.db.backends.postgresql_psycopg2', 73 'NAME': 'my_database', 74 'USER': os.environ.get('DB_USER'), 75 'PASSWORD': os.environ.get('DB_PASSWORD'), 76 'HOST': 'localhost', 77 'PORT': '5432' 78 } 79} 80 81 82# Password validation 83# https://docs.djangoproject.com/en/3.0/ref/settings/#auth-password-validators 84 85AUTH_PASSWORD_VALIDATORS = [ 86 { 87 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', 88 }, 89 { 90 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', 91 }, 92 { 93 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', 94 }, 95 { 96 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', 97 }, 98] 99 100 101# Internationalization 102# https://docs.djangoproject.com/en/3.0/topics/i18n/ 103 104LANGUAGE_CODE = 'ja' 105 106TIME_ZONE = 'Asia/Tokyo' 107 108USE_I18N = True 109 110USE_L10N = True 111 112USE_TZ = True 113 114 115# Static files (CSS, JavaScript, Images) 116# https://docs.djangoproject.com/en/3.0/howto/static-files/ 117 118STATIC_URL = '/static/' 119MEDIA_URL = '/media/' 120 121STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles') 122 123STATICFILES_DIRS = ( 124 os.path.join(BASE_DIR, 'static'), 125) 126 127MESSAGE_TAGS = { 128 messages.ERROR: 'alert alert-danger', 129 messages.WARNING: 'alert alert-warning', 130 messages.SUCCESS: 'alert alert-success', 131 messages.INFO: 'alert alert-info', 132} 133 134AUTH_USER_MODEL = 'accounts.CustomUser' 135 136SITE_ID = 1 137 138AUTHENTICATION_BACKENDS = ( 139 'allauth.account.auth_backends.AuthenticationBackend', 140 'django.contrib.auth.backends.ModelBackend', 141) 142 143# メール認証に切り替え 144ACCOUNT_AUTHENTICATION_METHOD = 'email' 145ACCOUNT_USER_REQUIRED = False 146 147# メール認証必須にする 148ACCOUNT_EMAIL_VERIFICATION = 'mandatory' 149ACCOUNT_EMAIL_REQUIRED = True 150 151# ログインとログアウトの遷移先を指定 152LOGIN_REDIRECT_URL = 'deploy_app:index' 153ACCOUNT_LOGOUT_REDIRECT_URL = 'account_login' 154 155# ログアウトリンクをクリックしたら、その時点でログアウト 156ACCOUNT_LOGOUT_ON_GET = True 157 158# 件名の接頭辞を空白にする 159ACCOUNT_EMAIL_SUBJECT_PREFIX = '' 160 161DEFAULT_FROM_EMAIL = 'admin@example.com' 162 163DEFAULT_AUTO_FIELD='django.db.models.AutoField' 164 165LOGIN_REDIRECT_URL = 'deploy_app:diary_list' 166 167# ロギング設定 168LOGGING = { 169 'version': 1, 170 'disable_existing_loggers': False, 171 172 # ロガーの設定 173 'loggers': { 174 # Djangoが利用するロガー 175 'django': { 176 'handlers': ['file'], 177 'level': 'INFO', 178 }, 179 # アプリが利用するロガー 180 'deploy_app': { 181 'handlers': ['file'], 182 'level': 'INFO', 183 }, 184 }, 185 186 # ハンドラの設定 187 'handlers': { 188 'file': { 189 'level': 'INFO', 190 'class': 'logging.handlers.TimedRotatingFileHandler', 191 'filename': os.path.join(BASE_DIR, 'logs/django.log'), 192 'formatter': 'prod', 193 'when': 'D', # 新しいファイルへの切り替えの間隔の単位 194 'interval': 1, # ログローテーションの切り替えの間隔 195 'backupCount': 7, # 保存しておくログファイル数 196 }, 197 }, 198 199 # フォーマッタの設定 200 'formatters': { 201 'dev': { 202 'format': '\t'.join([ 203 '%(asctime)s', 204 '[%(levelname)s]', 205 '%(pathname)s(Line.%(lineno)d)', 206 '%(message)s' 207 ]) 208 }, 209 } 210} 211 212if not DEBUG: 213 SECRET_KEY = os.environ['SECRET_KEY'] 214 import django_heroku #追加 215 django_heroku.settings(locals()) 216 217db_from_env = dj_database_url.config(conn_max_age=600, ssl_require=True) 218DATABASES['default'].update(db_from_env)
よろしくお願いします。
試したこと
以下のようにした後、デプロイしたとしてもmigrateをすると同じエラーが出ます。
Django
1import dj_database_url 2DATABASES['default'] = dj_database_url.config() 3SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
また、dbのUser
とPASSWORD
を直書きしても、上手くいきませんでした。
補足情報(FW/ツールのバージョンなど)
MacOS Big Sur 11.5.2
VSCode
Django 3.2.7
Python 3.7.12
heroku
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。