MyCoachのアプリがリリースされました。
アプリとは別で、Web版のMyCoachも作成しておりました。
実際のコンテンツの方はこちらをご覧ください。
(現在はまだβ期間として運用しております。)
https://mycoach.re-engines.com/top
こちらのWeb版はDocker環境を作って開発しておりました。
さて、今回はリリースを機に、開発中ではいじれなかったDocker環境を少し改修してみたので、そのことを記事にしたいと思います。
ただ既に多くの方がまとめてくださっている内容なので、そこまで目新しいものはないと思います。
今回は、既存プロジェクトに組み込むということで記載していきたいと思います。
今までは、RailsコンテナとMySQLコンテナの2つで構築しておりました。
コンパクトな構成ですね!
ただ、実際に本番でRailsを運用するときには、リバースプロキシを立てることが多いかと思います。
Dockerでも複数コンテナを組み合わせることで、そのような挙動を構築することができるので、ちょっと試してみたかったこともあります。
下記の4つのコンテナを使用します。
Datastoreというコンテナが出てきましたが、このコンテナで共通のファイルや保持しておきたいファイルを持たせておきます。
各項目に関してディレクトリを切ってDockerfileや関連ファイルを保存します。
こうすることで、各環境も管理しやすくなるかと思います。
├ docker ┬ datastore │ ├ mysql │ ├ nginx │ └ rails └ docker-compose.yml
ソースコードを載せると長くなってしまうので、リンクで失礼します。
https://github.com/naoki85/docker_rails/tree/master/docker
複数コンテナを扱うときには`docker-compose.yml`が便利ですね。
これで、`docker-compose up`コマンドでまとめて起動できます。
(ビルドするときには`docker-compose build`)
version: '2' services: datastore: build: context: . dockerfile: ./docker/datastore/Dockerfile server: build: context: . dockerfile: ./docker/nginx/Dockerfile ports: - 80:80 volumes_from: - datastore depends_on: - datastore web: build: context: . dockerfile: ./docker/rails/Dockerfile command: bundle exec unicorn -p 3000 -c /app/config/unicorn/development.rb ports: - 3000:3000 volumes: - .:/app volumes_from: - datastore depends_on: - db links: - db - db:database - db:mysql extends: file: ./docker/mysql/password.yml service: password db: build: context: . dockerfile: ./docker/mysql/Dockerfile ports: - 3306:3306 volumes_from: - datastore depends_on: - datastore extends: file: ./docker/mysql/password.yml service: password
そこまで複雑なことはしておりませんが、Railsのコンテナでは`unicorn`コマンドで起動しております。
また、service: password
を記述することで、後ほどdatabase.rb
にMySQLのパスワードを記述する際、password
と記述すれば解釈してくれます。
(普通にパスワードを記述しても大丈夫ですが。)
アプリケーションサーバーにはUnicornを使用します。
既にUnicornがインストールされていれば、Railsプロジェクト内にunicorn
ディレクトリがあるかと思いますので、新しくdevelopment.rb
を作成します(もしくは既にある場合は修正)。
worker_processes 8 pid "/var/run/unicorn.pid" listen "/share/unicorn.sock" stdout_path "./log/unicorn.stdout.log" stderr_path "./log/unicorn.stderr.log"
注意することは、host
で指定するDBは、docker-compose.yml
で指定したservice
名になります。
development: <<: *default database: app_development username: root password: root host: db
ここまでで、Docker環境を起動して、http://localhost
にアクセスしてみます(またはNginxで指定したホスト)。
これで、今まで通りのプロジェクトが表示されていれば成功です。
今回は既存プロジェクトでやってみましたが、新規プロジェクトでも同様の設定ができるかと思います。
Docker起動直後にアクセスすると、Nginxのエラー画面が表示されることがあります。
ちょっと待って、再度アクセスすると問題なく表示されているので、Unicornのプロセスが起動していないのかな、と思います。
この辺りを含め、改善した箇所などがあれば、随時更新していきたいと思います。
Docker良いですね。
私は最近PCを変えたのですが、プロジェクトの開発環境を整える際、Dockerさえインストールしてしまえば、すぐに開発環境を整えることができました。
(その点だけでいうと、Vagrantでもできるとは思いますが。。。)
MyCoachの方も継続してアップデートする予定なので、今後ともよろしくお願いします!