こんにちは。のっくんです。
この記事ではDjangoで作ったウェブアプリをPythonAnyWhereというクラウドにデプロイする方法を紹介します。
Webアプリ初心者の私が1から作ってデプロイしたアプリはこちら↓です。
J2のサッカー情報を発信するサイト:Soccer Talk
[toc]ユーザ登録
PythonAnyWhereの良いところはユーザ登録が簡単なところです。
ユーザ名とメールアドレスだけですぐに登録できます。
ちなみに、無料プランだとユーザ名がサイトのドメイン名に含まれることになります。
私の場合は以下の通り。
- ユーザ名:nokkun
- ドメイン名:nokkun.pythonanywhere.com
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-22.54.00-1024x561.png)
https://www.pythonanywhere.com/
登録してログインするとこんな感じ。
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-22.31.43-1024x410.png)
無料だとディスク容量は500MBまで使えます。
左下のBashボタンを押すと、、、
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-23.12.06-1024x544.png)
こんな感じですぐにBashが開けます。
さくらインターネットやAWSのVPSだとSSH接続するまでに、パネルから申請して、公開鍵・秘密鍵作って〜、とか色々面倒なのですがこちらはその必要がありません。
さらに、virtualenvやgitがすでにインストールされています。
なんて便利なんでしょう。
Githubにソースをpush
githubは、pythonanywhereにソースコードを一式コピーするのに使います。
githubを使いたくない人はdjangoのプロジェクトを一式zipにしてクラウド上でunzipしても良いです。
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-23.27.33-1024x631.png)
Githubにユーザ登録してpushするとこんな感じの画面になります。
gitでクローンする時のためにURLは覚えておきましょう。
デプロイ
コンソールでの設定
djangoプロジェクトのソースコードを以下のコマンドでダウンロードします。
hoge,fugaの部分は適宜自分のユーザ名などに変更してくださいね。
$ git clone https://github.com/hoge/fuga
プロジェクトがダウンロードできたら、virtualenvで仮装環境を作ります。
ちなみに私はローカルでAnacondaを使って開発していたのですが、pythonanywhereではvirtualenvを使う必要があります。
$ mkvirtualenv myenv --python=python3.6
pythonのバージョンは自分のローカル環境に合わせて指定してください。
myenvもただの名前なので何でも良いです。
pipでローカルで使っていたパッケージを入れます。
$ pip install django
requirements.txtを使って一気にパッケージ入れようとしたんですが、リソース使いすぎだからコンソール閉じると怒られてしまったので大人しく1つずつ入れることに。
web上での設定
pythonanywhereにサインインして、Add a new web appを選択してください。
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-19.36.16-1024x545.png)
言われた通りにボタンを押していくとwebアプリができます。
![](https://ymgsapo.com/wp-content/uploads/2018/10/68747470733a2f2f71696974612d696d6167652d73746f72652e73332e616d617a6f6e6177732e636f6d2f302f33363236312f63653538336265352d613863392d343338322d353433362d6532643762663939346532642e706e67-1024x778.png)
注意点としては、Python Web Frameworkを選択するときにDjangoではなく、Manual configulationを選択すること。ここでDjangoを選択するとPython2系が入ってしまいます。
webアプリが作れたら設定画面が出てくるのでそれぞれ設定して行きます。
仮想環境の設定
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-23-19.37.55-1024x769.png)
myenvを指定します。
WSGI Configuration Fileの編集
WSGI Configuration fileを編集します。
DJANGOの部分を以下のようにコメントアウトしましょう。
# +++++++++++ DJANGO +++++++++++ # To use your own django app use code like this: import os import sys # ## assuming your django settings file is at '/home/nokkun/mysite/mysite/settings.py' ## and your manage.py is is at '/home/nokkun/mysite/manage.py' path = '/home/nokkun/soccer_talk' if path not in sys.path: sys.path.append(path) os.environ['DJANGO_SETTINGS_MODULE'] = 'django_app.settings' # then: from django.core.wsgi import get_wsgi_application application = get_wsgi_application()
pathとsettingsの部分はご自分の環境に変更しましょう。
django_app/settings.pyであれば、’django_app.settings’になります。
settings.py
以下を追加。
# Pythonanywhere用の設定を追加 STATIC_ROOT = os.path.join(BASE_DIR, 'static') ALLOWED_HOSTS = ['localhost', '.pythonanywhere.com']
Bashで以下のコマンドを実行
$ python manage.py collectstatic
Static files
staticファイルの場所を追加しましょう。
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-24-0.32.56-1024x376.png)
Reload
2018/10/28日追記
最後にリロードします。これでアプリのページがちゃんと開ければOKです。
![](https://ymgsapo.com/wp-content/uploads/2018/10/スクリーンショット-2018-10-28-1.06.08-1024x452.png)
アプリを更新したい場合には、新しいソースコードをgit cloneしてからリロードすると更新できます。
リロードを忘れると更新されないことがあるので注意して下さい。
参考