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

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

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

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

Heroku

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

Python

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

Q&A

解決済

1回答

2507閲覧

herokuにデプロイするが、データベースがHTMLに反映されない

grimro92

総合スコア15

Django

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

Heroku

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

Python

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

1グッド

0クリップ

投稿2020/03/13 09:51

編集2020/03/14 13:31

前提・実現したいこと

python+django+herokuでブログサイトを作成しています。

herokuへのデプロイが終わりページを表示したところ、モデルを使用した箇所が表示されません。

ローカル環境では下画像1枚目のように記事が表示されるはずですが、オンライン環境だと下画像2枚目のように表示されません。

また、画像上部・画像右側の文字(プログラミング、ライフハック等)をクリックすると、Server Error (500)となります。

本来はクリックすると、クリックしたカテゴリの記事を一覧で表示します。

どこが間違っているのか分からないため教えてください。

イメージ説明イメージ説明

settings.py

import os import dj_database_url BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) SECRET_KEY = '○○○' DEBUG = False ALLOWED_HOSTS = ['*'] INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'blogs', ] 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 = 'aiblog.urls' TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], '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 = 'aiblog.wsgi.application' DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'NAME': 'name', 'USER': 'user', 'PASSWORD': '', 'HOST': 'host', 'PORT': '', } } 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', }, ] LANGUAGE_CODE = 'ja' TIME_ZONE = 'Asia/Tokyo' USE_I18N = True USE_L10N = True USE_TZ = True PROJECT_ROOT = os.path.dirname(os.path.abspath(__file__)) STATIC_URL = '/static/' STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),) STATIC_ROOT = os.path.join(PROJECT_ROOT, 'static') try: from .local_settings import * except ImportError: pass if not DEBUG: 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)

local_settings.py

import os BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } DEBUG = True

試したこと

こちらの記事を参考にしました。

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

python 3.8.0
appdirs==1.4.3
distlib==0.3.0
dj-database-url==0.5.0
Django==2.2
django-heroku==0.3.1
filelock==3.0.12
gunicorn==20.0.4
psycopg2==2.8.4
pytz==2019.3
six==1.14.0
sqlparse==0.3.1
virtualenv==20.0.10
whitenoise==4.1.3

s.k👍を押しています

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

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

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

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

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

nskydiving

2020/03/13 10:45

heroku logs でエラー内容を確認してください。
grimro92

2020/03/13 12:05

horoku logd実行結果がこちらです。 2020-03-13T11:58:22.293738+00:00 heroku[web.1]: Unidling 2020-03-13T11:58:22.309349+00:00 heroku[web.1]: State changed from down to starting 2020-03-13T11:58:30.663722+00:00 heroku[web.1]: Starting process with command `gunicorn aiblog.wsgi --log-file -` 2020-03-13T11:58:33.325136+00:00 app[web.1]: [2020-03-13 11:58:33 +0000] [4] [INFO] Starting gunicorn 19.9.0 2020-03-13T11:58:33.326008+00:00 app[web.1]: [2020-03-13 11:58:33 +0000] [4] [INFO] Listening at: http://0.0.0.0:11065 (4) 2020-03-13T11:58:33.326153+00:00 app[web.1]: [2020-03-13 11:58:33 +0000] [4] [INFO] Using worker: sync 2020-03-13T11:58:33.328052+00:00 app[web.1]: /app/.heroku/python/lib/python3.8/os.py:1021: RuntimeWarning: line buffering (buffering=1) isn't supported in binary mode, the default buffer size will be used 2020-03-13T11:58:33.328053+00:00 app[web.1]: return io.open(fd, *args, **kwargs) 2020-03-13T11:58:33.331369+00:00 app[web.1]: [2020-03-13 11:58:33 +0000] [9] [INFO] Booting worker with pid: 9 2020-03-13T11:58:33.382174+00:00 app[web.1]: [2020-03-13 11:58:33 +0000] [10] [INFO] Booting worker with pid: 10 2020-03-13T11:58:34.852750+00:00 heroku[web.1]: State changed from starting to up 2020-03-13T11:58:36.546073+00:00 app[web.1]: 10.67.225.150 - - [13/Mar/2020:20:58:36 +0900] "GET / HTTP/1.1" 200 2290 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36" 2020-03-13T11:58:36.545843+00:00 heroku[router]: at=info method=GET path="/" host=aiblogsite.herokuapp.com request_id=c284ff5b-4f63-445d-bed3-553e9259d43f fwd="123.227.40.180" dyno=web.1 connect=0ms service=183ms status=200 bytes=2481 protocol=https 2020-03-13T11:58:36.968748+00:00 heroku[router]: at=info method=GET path="/favicon.ico" host=aiblogsite.herokuapp.com request_id=cb8c6af3-86a9-485c-922f-aff7886df5b7 fwd="123.227.40.180" dyno=web.1 connect=0ms service=10ms status=404 bytes=258 protocol=https 2020-03-13T11:58:36.971275+00:00 app[web.1]: 10.67.225.150 - - [13/Mar/2020:20:58:36 +0900] "GET /favicon.ico HTTP/1.1" 404 77 "https://aiblogsite.herokuapp.com/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Sa fari/537.36" 2020-03-13T11:58:41.334086+00:00 heroku[router]: at=info method=GET path="/blog/programing/" host=aiblogsite.herokuapp.com request_id=b3455302-4a42-49a3-9ba3-07863ab00691 fwd="123.227.40.180" dyno=web.1 connect=0ms service=308ms status=500 bytes=234 protocol=https 2020-03-13T11:58:41.334400+00:00 app[web.1]: 10.67.225.150 - - [13/Mar/2020:20:58:41 +0900] "GET /blog/programing/ HTTP/1.1" 500 27 "https://aiblogsite.herokuapp.com/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.1 32 Safari/537.36" 2020-03-13T11:58:43.870436+00:00 heroku[router]: at=info method=GET path="/blog/lifehuck/" host=aiblogsite.herokuapp.com request_id=b84532da-3364-40a9-b1b1-ed6cde4e419b fwd="123.227.40.180" dyno=web.1 connect=0ms service=261ms status=500 bytes=234 protocol=https 2020-03-13T11:58:43.870249+00:00 app[web.1]: 10.67.225.150 - - [13/Mar/2020:20:58:43 +0900] "GET /blog/lifehuck/ HTTP/1.1" 500 27 "https://aiblogsite.herokuapp.com/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36" RuntimeWarning: line buffering (buffering=1) isn't supported in binary mode, the default buffer size will be used return io.open(fd, *args, **kwargs) この部分がエラーでしょうか?
guest

回答1

0

自己解決

2020/03/14に自己解決したので記載しておきます。上記のsettings.pyとlocal_settings.pyは最終的にうまくいった内容に変更しています。参考にしてください。

結論から言うと、『herokuのデータベースはローカルのデータベースとは別なので、デプロイ後に
https://自分のサイト.herokuapp.com/adminからもう一度データをいれる必要があった。』でした。

参考にしたサイト

投稿2020/03/14 13:44

grimro92

総合スコア15

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問