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

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

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

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

Heroku

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

解決済

HerokuにデプロイしたDjangoアプリケーションのadmin画面が表示されない

mimura_yusuke
mimura_yusuke

総合スコア0

Django

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

Heroku

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

1回答

0評価

0クリップ

2404閲覧

投稿2019/10/20 11:24

前提

Djangoで作成したアプリケーションをHerokuにデプロイしました。
デプロイ自体は成功し、テンプレートファイル(4つあります)は正常に表示されています。
しかし、ローカルでは表示されていた管理画面だけが表示されません。

発生している問題・エラーメッセージ

https://appname.herokuapp.com/admin/にアクセスしようとすると、「Server Error (500)」というメッセージが表示され、管理画面にアクセスすることができません。
heroku logs -tでログを確認すると、以下のようになっています。

2019-10-20T10:28:09.822462+00:00 app[web.1]: 10.xxx.xxx.xxx - - [20/Oct/2019:10:28:09 +0000] "GET /admin/ HTTP/1.1" 302 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36" 2019-10-20T10:28:10.187454+00:00 heroku[router]: at=info method=GET path="/admin/login/?next=/admin/" host=appname.herokuapp.com request_id=be8ca4bf-cb65-4af9-9035-0319ba1860ab fwd="110.xxx.xxx.xxx" dyno=web.1 connect=0ms service=36ms status=500 bytes=234 protocol=https 2019-10-20T10:28:10.185499+00:00 app[web.1]: 10.xxx.xxx.xxx - - [20/Oct/2019:10:28:10 +0000] "GET /admin/login/?next=/admin/ HTTP/1.1" 500 27 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"

該当のソースコード

デプロイに関係しそうなファイルの状況はいかのとおりです。

ディレクトリ構造

project ←プロジェクト名 appname ←アプリケーション名 static staticfiles templates venv .gitignore db.sqlite3 manage.py Procfile requirements.txt runtime.txt

settings.py

python

import os import dj_database_url # Build paths inside the project like this: os.path.join(BASE_DIR, ...) BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! # SECURITY WARNING: don't run with debug turned on in production! DEBUG = False ALLOWED_HOSTS = ['*'] # Application definition INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'appname', ] MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ] ROOT_URLCONF = 'appname.urls' TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [BASE_DIR, 'templates'], 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ] WSGI_APPLICATION = 'appname.wsgi.application' # Database # https://docs.djangoproject.com/en/2.2/ref/settings/#databases DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'NAME': 'name', 'USER': 'user', 'PASSWORD': '', 'HOST': 'host', 'PORT': '', } } # Password validation # https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ { 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', }, { 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', }, { 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', }, { 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', }, ] # Internationalization # https://docs.djangoproject.com/en/2.2/topics/i18n/ LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/2.2/howto/static-files/ STATIC_URL = '/static/' STATICFILES_DIRS =( os.path.join(BASE_DIR, 'static'), ) STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles') #追加 STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'#追加 try: from .local_settings import * except ImportError: pass if not DEBUG: SECRET_KEY = os.environ['SECRET_KEY'] import django_heroku #追加 django_heroku.settings(locals()) #追加 db_from_env = dj_database_url.config(conn_max_age=600, ssl_require=True) DATABASES['default'].update(db_from_env)

requirements.txt

dj-database-url==0.5.0 Django==2.2.5 django-heroku==0.3.1 gunicorn==19.9.0 psycopg2==2.8.3 pytz==2019.2 sqlparse==0.3.0 whitenoise==4.1.4

wsgi.py

import os from django.core.wsgi import get_wsgi_application os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'projectname.settings') application = get_wsgi_application()

試したこと・実行したコマンド

デプロイ当初は、

heroku config:set DISABLE_COLLECTSTATIC=1

と設定していたので、

heroku config:set DISABLE_COLLECTSTATIC=0

でcolliectstaticが自動実行される設定に戻しました。

また、

heroku run python manage.py migrate
heroku run python manage.py createsuperuser

はともに実行済みで、エラーなく完了しています。

staticファイル関係の設定が原因かと思い、ローカル環境にて

python manage.py collectstatic

herokuにて

heroku run python manage.py collectstatic --noinput

を実行し、特にエラー等発生せず完了しています。

デプロイに必要なファイルの作成及び修正は以下の情報に基づいて行いました。
https://qiita.com/frosty/items/66f5dff8fc723387108c

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

OS:Windows10 home 64bit
IDE:Visual Studio Code
Python:3.7.4
Django:2.2.5

デプロイ、マイグレーション、スーパーユーザの作成ともに成功しているため、どこに原因があるのか分かりません。staticファイル関係の設定が原因かもしれませんが、どの設定が誤っているのか見当がつきません。
何卒ご教授のほどよろしくお願いいたします。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Django

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

Heroku

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