質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

0回答

2086閲覧

puma.sock failed (11: Resource temporarily unavailable) while connecting to upstreamというエラーが出てサイトが落ちる

nippledrill

総合スコア11

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/07/29 20:34

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; } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yu_1985

2020/07/29 23:08

インスタンスタイプはどれですか? ELBのヘルスチェックではなくEC2インスタンスのステータスチェックが失敗しているというのはスペック不足が考えられますが…。
nippledrill

2020/07/30 03:09

ありがとうございます。 Amazon Linux 2 AMI t2.microです。
yu_1985

2020/07/30 03:13

cloudwatchでCPU使用率の推移を見るのと、サーバの中に入ってメモリの使用率を見てみてください。 いろんな見方がありますが、時間経過による変化を見るならsar、とりあえず今の状態を見たいならfreeかtopあたりで見ればいいでしょう。 https://qiita.com/muiyama/items/956ac41c4cf6cf85ae12 https://qiita.com/hiro-d/items/c3f724cb3d377e21cd91#sar https://qiita.com/k0kubun/items/7368c323d90f24a00c2f 経験上RailsやらDockerやらをガリガリ動かすならt2.microのメモリ1GBだと大体足りないような気はしますが…。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問