前提・実現したいこと
ECS上でnginxとRails(puma)を使用してのデプロイをしたい。
現在ローカル上では、
Docker上でRailsコンテナ、nginxコンテナ、MySQLコンテナを使用し
Rails(Puma)とnginxはsocket通信にて連携を行っています。
Dockerfile
1FROM ruby:2.6.6 2 3RUN apt-get update -qq && apt-get install -y --no-install-recommends \ 4 build-essential \ 5 libpq-dev \ 6 nodejs \ 7 && apt-get clean \ 8 && rm -rf /var/lib/apt/lists/* 9 10RUN apt-get update && apt-get install -y unzip && \ 11 CHROME_DRIVER_VERSION=`curl -sS chromedriver.storage.googleapis.com/LATEST_RELEASE` && \ 12 wget -N http://chromedriver.storage.googleapis.com/$CHROME_DRIVER_VERSION/chromedriver_linux64.zip -P ~/ && \ 13 unzip ~/chromedriver_linux64.zip -d ~/ && \ 14 rm ~/chromedriver_linux64.zip && \ 15 chown root:root ~/chromedriver && \ 16 chmod 755 ~/chromedriver && \ 17 mv ~/chromedriver /usr/bin/chromedriver && \ 18 sh -c 'wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add -' && \ 19 sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list' && \ 20 apt-get update && apt-get install -y google-chrome-stable 21 22RUN mkdir /myapp 23WORKDIR /myapp 24 25COPY Gemfile /myapp/Gemfile 26COPY Gemfile.lock /myapp/Gemfile.lock 27 28RUN bundle install 29COPY . /myapp
Dockerfile
1FROM nginx:1.15.8 2 3RUN rm -f /etc/nginx/conf.d/* 4 5ADD nginx.conf /etc/nginx/conf.d/myapp.conf 6 7CMD /usr/sbin/nginx -g 'daemon off;' -c /etc/nginx/nginx.conf 8
【nginx.conf】 upstream myapp { # ソケット通信したいのでpuma.sockを指定 server unix:///myapp/tmp/sockets/puma.sock; } server { listen 80; server_name localhost; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; root /myapp/public; client_max_body_size 100m; error_page 404 /404.html; error_page 505 502 503 504 /500.html; try_files $uri/index.html $uri @myapp; keepalive_timeout 5; location @myapp { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_pass http://myapp; } }
【docker-compose.yml】 version: '3' services: # Railsコンテナ定義 web: build: . command: bundle exec puma -C config/puma.rb volumes: - .:/myapp:cached - public-data:/myapp/public - tmp-data:/myapp/tmp - log-data:/myapp/log ports: - "3000:3000" depends_on: - db tty: true stdin_open: true db: image: mysql:5.7 volumes: - ./tmp/db:/var/lib/mysql ports: - "3306:3306" environment: MYSQL_DATABASE: app_development MYSQL_ROOT_PASSWORD: password nginx: build: context: containers/nginx volumes: - public-data:/myapp/public - tmp-data:/myapp/tmp ports: - "80:80" depends_on: - web volumes: public-data: tmp-data: log-data: db-data:
【puma.rb】 threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 } threads threads_count, threads_count port ENV.fetch("PORT") { 3000 } environment ENV.fetch("RAILS_ENV") { "development" } pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" } plugin :tmp_restart app_root = File.expand_path("../..", __FILE__) bind "unix://#{app_root}/tmp/sockets/puma.sock" stdout_redirect "#{app_root}/log/puma.stdout.log", "#{app_root}/log/puma.stderr.log", true
下記qiita記事を参考に、
ECRへpush、VPC、EC2、RDS、ALB、タスク定義、クラスターの作成、サービスの作成を行いました。
https://qiita.com/saongtx7/items/f36909587014d746db73
発生している問題・エラーメッセージ
ALBのDNS名にアクセスすると、503 service temporarily unavailable
となってしまい、アプリが表示されない状況です。
EC2にSSH接続をし、
Railsコンテナ内でアプリソースの確認や、rails db:create,migrate のあと、rails consoleにてデータベースの確認、
nginxコンテナ内でtmp/socketsディレクトリ、uploadsディレクトリの確認はできています。
SSH接続後、railsコンテナ内に入るとなぜか頻繫にコンテナが落ちます。
これが一つの原因かも?と思い、調べたところ
ALBのヘルスチェックにひっかって、コンテナの死亡と再生が繰り返されているような気がするのですが、
私の理解不足でここから分からず。。
どなたか教えていただけると幸いです。
上記qiita記事内
taskのRailsのログを見ると
puma側ではUse Ctrl-C to stopと最後のメッセージで表示されているので
起動はしているのではないかと思います。
※タスク定義のコマンドにてbundle exec puma -C config/puma.rbを指定
あなたの回答
tips
プレビュー