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

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

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

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

Heroku

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

Q&A

解決済

1回答

5697閲覧

ModuleNotFoundErrorを解消したい

aushijima

総合スコア55

Django

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

Heroku

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

0グッド

1クリップ

投稿2018/08/07 07:16

実現したいこと

DjangoをHerokuにデプロイして、アプリケーションエラーを解消したいです。

出ている問題点・気になる点

heroku logsで見てみた所

ModuleNotFoundError: No module named 'mySite.wsgi'

というエラーと

2018-08-07T05:38:41.036894+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=django-ushijima.herokuapp.com request_id=3e13c260-74f5-4fec-8293-8e7ba671fba7 fwd="202.231.92.196" dyno= connect= service= status=503 bytes= protocol=https

というエラーが出ています。

試してみたこと

  • code=H10の時に下記のurlで、アプリケーションエラーが出るという記載があった為、試してみましたが、解消できませんでした。

https://qiita.com/Oakbow/items/1565922ddcdea0ce9ab5

  • Procfileの
web: gunicorn my_env.wsgi --log-file -

web: gunicorn mySite.wsgi --log-file -

に変更したりなどしました。

ディレクトリ構成

├─my_env(プロジェクト)
│ ├─.idea
│ ├─heroku_django(仮想環境)
│ └─mySite
│ ├─├─books
│ ├─│ ├─migrations
│ ├─│ │ └─__pycache__
│ ├─│ └─__pycache__
│ ├─├─myapp
│ ├─│ ├─migrations
│ ├─│ │ └─__pycache__
│ ├─│ └─__pycache__
│ ├─├─mySite
│ ├─│ └─___init__.py
│ ├─│ └─settings.py
│ ├─│ └─urls.py
│ ├─│ └─wsgi.py
│ ├─ └─templates
│ ├─│ ├─admin
│ ├─│ └─myapp
│ ├─│ └─templates
│ ├─├─db.sqlite3
│ ├─├─manage.py
│ └─.gitignore
│ └─Procfile
│ └─requirements.txt
│ └─runtime.txt

requirements.txtの中身

asn1crypto==0.24.0 cffi==1.11.5 cryptography==2.3 dj-database-url==0.5.0 dj-static==0.0.6 Django==2.1 django-toolbelt==0.0.1 gunicorn==19.9.0 idna==2.7 psycopg2==2.7.5 pycparser==2.18 PyMySQL==0.9.2 pytz==2018.5 six==1.11.0 static3==0.7.0

mod_wsgiなどは、Apacheを使用する時には必要ということで、Djangoで、使用できるgunicornで今回はやりたいと思います。

エラーの原因がProcfileの記載の仕方なのかsetting.pyの記載に問題があるのか分かりません。良かったら教えてください。

また、ファイル構成などは、実務で考えたりしたことがないのでこうした方がいいなどがあれば良かったら教えてください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

gunicornは利用したことがないのですが・・・ちょっと調べてみました。

どうやら、gunicornがXXX.wsgiを認識するためには、プロジェクトがpython pathに載ってないといけないようです。

下記の方法でも、代替えできるようです。
Running Gunicorn - Integration - Django

web: gunicorn --env DJANGO_SETTINGS_MODULE=mySite.settings mySite.wsgi --log-file -

追記

Herokuについても調べてみましたが、Procfileからの相対パスになるようですね。
よくあるDjangoのプロジェクトは、mySite(my_envの一つ下)がルートになっているので、
例が、それを前提に書かれているように感じます。

試す時間が割けず、申し訳ないですが、下記のどちらかで、動作しないか、お試しください。

// my_env/mySite下に__init__.pyが必要 web: gunicorn mySite.mySite.wsgi --log-file -
web: gunicorn --pythonpath mySite mySite.wsgi --log-file -

投稿2018/08/08 04:46

編集2018/08/09 07:28
Meganezaru

総合スコア715

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

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

aushijima

2018/08/09 02:58

書き込みありがとうございました。試してみましたが、ダメでした。
Meganezaru

2018/08/09 07:30

実務経験がない回答で申し訳ないですが、 追記しましたので、時間があればお試しください。 もしくは、実務経験者の回答にご期待ください(;'∀')
aushijima

2018/08/10 02:14

ありがとうございます。試してみましたが、ダメでした..
Meganezaru

2018/08/10 02:54

念のため確認ですが、修正したのち、git pushはされてるんですよね?
aushijima

2018/08/10 03:36

git push heroku masterにpushは、していますね。heroku側のActivityの所でもデプロイはうまくいっていると表示されていますね。
Meganezaru

2018/08/10 05:59 編集

ならば、my_env/mySite/__init__.pyは残ってると思いますので その状態で、 web: gunicorn --env DJANGO_SETTINGS_MODULE=mySite.mySite.settings mySite.wsgi --log-file - を試してもらって、これでダメなら、私はお手上げですw
aushijima

2018/08/13 01:07

ありがとうございます。返信が、遅くなってしまいました。 ダメでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問