質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

870閲覧

HerokuにDjangoアプリをデプロイした後、migrateするとエラーが出る

kawataku

総合スコア3

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/09/22 05:26

前提・実現したいこと

作成したDjangoのアプリをherokuにデプロイしたのですが、migrateすると、以下のようなエラーが出ます。
このエラーを解決したいです。

追加の質問

  • settings.pyに書くdbのnameuserなどは、ローカルにある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のUserPASSWORDを直書きしても、上手くいきませんでした。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

前提・実現したいこと

作成したDjangoのアプリをherokuにデプロイしたのですが、migrateすると、以下のようなエラーが出ます。
このエラーを解決したいです。

追加の質問

  • settings.pyに書くdbのnameuserなどは、ローカルにある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のUserPASSWORDを直書きしても、上手くいきませんでした。

補足情報(FW/ツールのバージョンなど)

MacOS Big Sur 11.5.2
VSCode
Django 3.2.7
Python 3.7.12
heroku

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

settings.pyに書くdbのnameやuserなどは、ローカルにあるpostgresqlの名前やユーザー名で良いのでしょうか?

それとも、heroku側に作り出した、Postgresqlの名前やユーザ名になるのでしょうか?
その場合は、heroku側のpostgresqlのユーザ名やパスワードを取得する方法を教えていただけるとありがたいです。

下のURLからheroku上のDBのホスト名、ユーザー名、パスワードが取得出来ますのでそこからそれらを取得してPostgreSQLに接続してマイグレーションを実行すればいいかと思います。

投稿2021/09/26 13:09

yuokada

総合スコア550

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問