Docker + Rails + Puma + Nginx + MySQL構成をawsのec2サーバーに本番環境でデプロイしました。
その日はずっとサイトにアクセスできるのですが、翌日になると502 bad gatwayと表示されてしまう現象をここ最近繰り返している状況です。
その度にec2インスタンスにsshしてdocker-compose up -dでコンテナを立ち上げて、再びサイトにアクセスできるようにしているのですが、次の3つが問題として毎回起きています。
①ec2インスタンス接続時にコネクションタイムアウトと表示されるので、ec2インスタンスが落ちている?。ちなみにawsのコンソール画面上ではステータスチェックが1/2となっている。解決策としてインスタンスを停止→開始すると接続できるようになる。2/2になる。
②docker-compose psでコンテナ起動状況を確認するとappコンテナだけ落ちている。dbとwebはup状態。
③docker-compose logsでログを確認すると最後の方で
ec2
1 *19520 connect() to unix:///myapp/tmp/sockets/puma.sock failed (11: Resource temporarily unavailable) while connecting to upstream, client: 10.0.1.147, server: localhost, request: "GET / HTTP/1.1", upstream: "http://unix:///myapp/tmp/sockets/puma.sock:/", host: "10.0.0.239"
というエラーを数行にわたって吐いている。
私の認識としては、タイトルのエラーで検索した結果何かの値の上限を上げてあげればいいのかなという程度のことしか分からないのですが、原因が分かる方、教えていただけますでしょうか。
Dockerfile
1FROM ruby:2.5.3 2 3RUN apt-get update -qq && \ 4 apt-get install -y build-essential \ 5 libpq-dev \ 6 nodejs \ 7 vim 8RUN apt-get update && apt-get install -y unzip && \ 9 CHROME_DRIVER_VERSION=`curl -sS chromedriver.storage.googleapis.com/LATEST_RELEASE` && \ 10 wget -N http://chromedriver.storage.googleapis.com/$CHROME_DRIVER_VERSION/chromedriver_linux64.zip -P ~/ && \ 11 unzip ~/chromedriver_linux64.zip -d ~/ && \ 12 rm ~/chromedriver_linux64.zip && \ 13 chown root:root ~/chromedriver && \ 14 chmod 755 ~/chromedriver && \ 15 mv ~/chromedriver /usr/bin/chromedriver && \ 16 sh -c 'wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add -' && \ 17 sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list' && \ 18 apt-get update && apt-get install -y google-chrome-stable 19 20RUN apt-get install -y vim 21 22RUN mkdir /myapp 23 24WORKDIR /myapp 25 26ADD Gemfile /myapp/Gemfile 27ADD Gemfile.lock /myapp/Gemfile.lock 28 29RUN gem install bundler 30RUN bundle install 31 32ADD . /myapp 33 34RUN mkdir -p tmp/sockets 35RUN mkdir -p tmp/pids
docker-compse.yml↓
version: '3' services: db: image: mysql:5.7 environment: MYSQL_ROOT_PASSWORD: password MYSQL_USER: user MYSQL_PASSWORD: 1234 MYSQL_DATABASE: myapp_db volumes: - mysql-data:/var/lib/mysql ports: - "4306:3306" app: build: . command: bundle exec puma -C config/puma.rb volumes: - .:/myapp - public-data:/myapp/public - tmp-data:/myapp/tmp - log-data:/myapp/log depends_on: - db web: build: context: containers/nginx volumes: - public-data:/myapp/public - tmp-data:/myapp/tmp ports: - 80:80 depends_on: - app volumes: mysql-data: public-data: tmp-data: log-data:
nginx.conf↓
upstream myapp { server unix:///myapp/tmp/sockets/puma.sock; } server { listen 443 ssl; server_name www.home-study.gq; 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; } }
あなたの回答
tips
プレビュー