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

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

新規登録して質問してみよう
ただいま回答率
85.48%
docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

nginx

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

Ruby on Rails

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

Docker

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

Q&A

解決済

1回答

1302閲覧

502 Bad Gatewayとなる

smilax630

総合スコア34

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

nginx

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

Ruby on Rails

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

Docker

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

1グッド

1クリップ

投稿2020/01/26 22:58

編集2020/01/27 01:41

ec2にデプロイしたのですが502 Bad Gateway nginx/1.15.8と表示されます
nginexのエラーログを見ると下記のようになってしました。
解決方法を教えていただけないでしょうか。

docker-compose.yml

version : '3' services: db: image: mysql:5.7 environment: MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: root volumes: - ./docker/db/data:/var/lib/mysql ports: - "3306:3306" web: tty: true stdin_open: true build: . command: /bin/sh -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" volumes: - .:/my_song ports: - "3000:3000" links: - db server: build: context: containers/nginx volumes: - ./nginx/log:/var/log/nginx - public-data:/my_song/public 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 }.to_i threads threads_count, threads_count port ENV.fetch("PORT") { 3000 } environment ENV.fetch("RAILS_ENV") { "development" } 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

containers/nginx.conf

# プロキシ先の指定 # Nginxが受け取ったリクエストをバックエンドのpumaに送信 upstream my_song { # ソケット通信したいのでpuma.sockを指定 server unix:///my_song/tmp/sockets/puma.sock; } server { listen 80; # ドメインもしくはIPを指定 server_name example.com [or 54.65.94.96 [or localhost]]; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; # ドキュメントルートの指定 root /my_song/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 @my_song; keepalive_timeout 5; # リバースプロキシ関連の設定 location @my_song { 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://my_song; } }
2020/01/26 22:43:56 [crit] 7#7: *38 connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory) while connecting to upstream, client: 27.121.160.193, server: example.com, request: "GET / HTTP/1.1", upstream: "http://unix:///my_song/tmp/sockets/puma.sock:/500.html", host: "54.65.94.96" 2020/01/26 22:43:58 [crit] 7#7: *38 connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory) while connecting to upstream, client: 27.121.160.193, server: example.com, request: "GET /favicon.ico HTTP/1.1", upstream: "http://unix:///my_song/tmp/sockets/puma.sock:/favicon.ico", host: "54.65.94.96", referrer: "http://54.65.94.96/" 2020/01/26 22:43:58 [crit] 7#7: *38 connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory) while connecting to upstream, client: 27.121.160.193, server: example.com, request: "GET /favicon.ico HTTP/1.1", upstream: "http://unix:///my_song/tmp/sockets/puma.sock:/500.html", host: "54.65.94.96", referrer: "http://54.65.94.96/" 2020/01/26 22:55:53 [crit] 7#7: *45 connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory) while connecting to upstream, client: 27.121.160.193, server: example.com, request: "GET / HTTP/1.1", upstream: "http://unix:///my_song/tmp/sockets/puma.sock:/", host: "54.65.94.96" 2020/01/26 22:55:53 [crit] 7#7: *45 connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory) while connecting to upstream, client: 27.121.160.193, server: example.com, request: "GET / HTTP/1.1", upstream: "http://unix:///my_song/tmp/sockets/puma.sock:/500.html", host: "54.65.94.96"
DrqYuto👍を押しています

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

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

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

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

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

final_mikan

2020/01/27 01:05

ログにある通り、 nginxとpumaがうまく連携取れていません nginxの設定ファイル(.conf)のupsteamなどがどう設定されているか記述すると回答がつきやすくなると思います
smilax630

2020/01/27 01:08

返信ありがとうございます! 追加いたしました!
final_mikan

2020/01/27 01:11

/my_song/tmp/sockets/puma.sockが存在しないというエラーメッセージです /my_song/tmp/sockets/puma.sockはありますか?
smilax630

2020/01/27 01:29 編集

確認したところありませんでした。 つまり、pumaとのソケット通信がうまくいっていないということですか?
final_mikan

2020/01/27 01:50

そういうことになりますね 以下を確認してもらえますか 1、ec2内pumaが起動しているか確認 2、nginx.confに設定したsockのパスにsockを作れていない(puma.rbのパス指定が間違っているなど) docker-composeの追記がありましたが、ec2内でdocker-composeを動かしてるのでしょうか?
smilax630

2020/01/27 01:54 編集

返信ありがとうございます! はい!ec2内でdocker-composeを動かしています!確認したら、肝心のアプリケーションコンテナ(web)が起動していませんでした。そのため、pumaが稼働していなかったということだと思います。 ローカル環境ではしっかり稼働していたのですが、本番環境になった途端立ち上げてもすぐに落ちてしまいます。 docker-compose.ymlを追記しましたので、本番環境で問題になりそうなところはあるでしょうか。
final_mikan

2020/01/27 02:13

pumaはあまりよくわからないので間違っていたら申し訳ないですが docker-composeで走らせるのはrails sではなくて bundle exec puma -e production -C <適用するpuma.rbのパス>みたいなものじゃないんですかね 今のcomposeだとpumaが起動した際のenvironmentはdevelopmentと表示されると思うのですがどうでしょう
guest

回答1

0

ベストアンサー

connect() to unix:///my_song/tmp/sockets/puma.sock failed (2: No such file or directory)

/my_song/tmp/sockets/puma.sock が無いといわれているので、存在の有無を確認しましょう。

無ければ、pumaの起動時に生成されるファイルなので、pumaが起動しているか確認しましょう。

投稿2020/01/27 01:37

yukky1201

総合スコア2751

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

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

smilax630

2020/01/27 01:45

返信ありがとうございます! 肝心のアプリケーションコンテナ(web)が起動していませんでした。 ローカル環境ではしっかり稼働していたのですが、本番環境になった途端立ち上げてもすぐに落ちてしまいます。 docker-compose.ymlを追記しましたので、本番環境で問題になりそうなところはあるでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問