> For the complete documentation index, see [llms.txt](https://akrgt.gitbook.io/otree-jp/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://akrgt.gitbook.io/otree-jp/fan-wai/otreewoamazon-ec2dettemiru.md).

# oTreeをAmazon EC2で使ってみる

ホントはHeroku推奨のようですが，その他サーバを使ってたり，会計処理を一本化するためにAmazon EC2を利用してますよ，ってことでEC2へのインストール方法について．

実はそこまで情報ゴリゴリではない（サーバの扱いとか詳しくない）ので，スコまで明るくはないのですがログとして残しておくとこれからのためになるだろう，ってことで参考までに．

## EC2の設定

![](/files/-LUO8HMDkPUgLbILW6Ty)

新しいインスタンスを作ります．

その後，Windowsで検索をして，これを使います．

![](/files/-LUO8uhmKrgmUe1_xOup)

もっといいのがあるのかもしれないけど，とりあえずこれで．

このプランにします，というのもインストール作業がなかなか時間かかってイライラするので，ここだけ課金しまくり．

EC2のメリットはスケーラブルに動かせるので，必要な時に課金すればサクサク作業ができるのがありがたいです．

![](/files/-LUO9V8M0f72ybHoAlb1)

と，この調子で書き続けると流石にしんどいので詳しい人に任せておいて，

※こちらなどを参照．

あと，やらないとまずいのは以下のこと．

* Elastic IPの割り振り

![](/files/-LUOGogaUgvWQx1XnfE5)

![](/files/-LUOH9RnENyqocPPD9hT)

![](/files/-LUOHGTUvF6Hv4b-ZuZn)

* ポートの開放

![](/files/-LUOI0_Cnmi05KnitJR8)

HTTPを開けておかないと外部との通信ができない＝ブラウザでアクセスできません．

一気にサーバの設定から．

これからはAnacondaによるPythonのインストール，Postgresqlのインストール，redisのインストール，そしてoTreeのインストールへ．

## サーバ上の作業

### AnacondaによるPythonのインストール

基本的に新しいPython3シリーズが入ればよいのですが（今は6や7か）使い慣れているのがAnacondaなのでAnacondaにします．ただそれだけの理由なので，別に何でも良いと思うのですが．．．

ここから[ダウンロード](https://www.anaconda.com/download/)．

![](/files/-LUOBSz5TO1T39Z6iUBI)

素直にダウンロード．

![](/files/-LUOBcmp5AOZ3ekxRvCx)

非推奨だけど，Pathを通しておいた方が良さげ．

![](/files/-LUODl_uUGPHtDo9Ishw)

インストールできたっぽいので次へ．

![](/files/-LUODy6JpkbPw-7KCaVN)

ついでにVisual Studio Codeを入れておいた方が楽なので入れておきましょう．

Windows上でコードを触ることはないのですが，一応入れておきます．

基本的には手元のMacでコードを書く→Dropboxで同期させる→実行するって環境を作っているのであまり実はそこまで困らなかったりします．

![](/files/-LUOEHS1cLRnhV5RvBWS)

さて，インストールできました．

※実はoTreeはPython 3.7ではまだ調子がよろしくないらしい（正確には，otree\_utilsというパッケージが）．なので一度Anaconda 3でPython 3.7をインストールした後にバージョンを落とすという作業をしました．

Anacondaナビゲータを使えば簡単

![](/files/-LUORlr7HLaY-5fvwyEx)

．．．しかし時間がかかるなぁ．

しかし，otree\_utilsを使わなければ別にいらないコストなのですが．

### Postgresqlのインストール

oTreeはSQLiteが入っていてもともと使える感じなのですが，本気の実験するにはPostresqlとかを使ったほうが良いよと推奨されているのでPostgresqlを[ここから](https://www.enterprisedb.com/downloads/postgres-postgresql-downloads)ダウンロード．

11シリーズでうまく進まなかったことがあるので，今回は確実な10シリーズでいってみようと思います．

![](/files/-LUOFBMDXwwt3XUF6fmp)

基本的にはPathも何もそのまま．

いろいろ全部インストールしておきます．

![](/files/-LUOFVOihGApE5b-VM1T)

ここのパスは忘れたらどうにもならないので覚えておきましょう．

![](/files/-LUOFghxe6xTmb3EfBnO)

![](/files/-LUOFoZUhJZ2e7TyChFy)

ポート番号はデフォルトで良さそう．

![](/files/-LUOG8OeW-10BAVOaA6r)

日本の設定を入れておこう．

そうすれば勝手に上手いことしておいてくれるでしょう．

あ，あと環境変数への追加を忘れてはいけません．

![](/files/-LUOMTCwvyMoF4TR5Iie)

その先のこともやっておきましょう．

pgAdminを使って，`django_db`という名前のデータベースを作ります．

この画面に入る時にインストール時に設定したパスワードが求められます．

![](/files/-LUOa1aKdJQuUUDjhsem)

### Redisのインストール

[ここ](https://github.com/MicrosoftArchive/redis/releases)からRedis for Windowsをインストールします．

![](/files/-LUOIOaBR9pkCHqK4CBL)

Pathは通しておきます．

![](/files/-LUOIfgxgjJ-cmPGVDgD)

特にいじりません．

![](/files/-LUOIpBTXZ0bB5J1fWiM)

### oTreeのインストール

&#x20;あとはPowershellで動かしていきます．

oTreeのインストールは「oTreeのインストールと起動」をご覧ください．

### psycopg2のインストール

### Firewallの設定

いかんせん，外部からアクセスするためにはサーバ内部のFirewallも設定が必要です．

Inbound Rulesを設定します．

![](/files/-LUOOX3i6bhwTVLxIThF)

New Rulesで80番を開ければ大丈夫．

All ConnectionをAllowします．

これで無事にoTreeサーバとして機能し始めました．

![](/files/-LUOax7G2BkJbrD03olr)

外部からアクセスしてます．


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://akrgt.gitbook.io/otree-jp/fan-wai/otreewoamazon-ec2dettemiru.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
