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

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

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

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

nginx

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

Ruby on Rails

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

Q&A

解決済

1回答

2490閲覧

unicorn nginxでfailed (111: Connection refused) while connecting to upstreamエラー

ruby_0ct

総合スコア57

unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

nginx

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

Ruby on Rails

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

0グッド

0クリップ

投稿2018/05/10 13:42

Railsアプリケーションをデプロイしてアクセスすると、We're sorry, but something went wrong.の502エラーでnginxのログを確認してみると、

connect() failed (111: Connection refused) while connecting to upstream

エラーになっていました。
調べてみると、unicorn.sockあたりの設定だというのですが、見直しても間違っていないと思います。
他に原因があるのでしょうか?
解決策をいただけると助かります。

unicorn.rb

rails_root = File.expand_path('../../../', __FILE__) ENV['BUNDLE_GEMFILE'] = rails_root + "/Gemfile" worker_processes 2 timeout 30 preload_app true stderr_path File.expand_path('../../../../log/unicorn_stderr.log', __FILE__) listen "/var/www/RailsApp/current/tmp/sockets/.unicorn.sock" app_path = File.expand_path('../../../', __FILE__) shared_path = File.expand_path('../../../../shared/', __FILE__) before_fork do |server, worker| defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect! old_pid = "#{server.config[:pid]}.oldbin" if old_pid != server.pid begin sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU Process.kill(sig, File.read(old_pid).to_i) rescue Errno::ENOENT, Errno::ESRCH end end end after_fork do |server, worker| defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection end

default.conf

error_log /var/www/RailsApp/current/log/nginx.error.log; access_log /var/www/RailsApp/current/log/nginx.access.log; client_max_body_size 2G; upstream app_server { server unix:/var/www/RailsApp/current/tmp/sockets/.unicorn.sock; } server { listen 443 ssl; server_name ドメイン名; keepalive_timeout 5; root /var/www/RailsApp/current/public; try_files $uri/index.html $uri.html $uri @app; location @app { # HTTP headers proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://127.0.0.1:3000; } error_page 500 502 503 504 /500.html; location = /500.html { root /var/www/RailsApp/current/public; } }

nginx.conf

user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; keepalive_timeout 65; include /etc/nginx/conf.d/default.conf; }

行ったこと

UNIXドメインソケットではなく、INETドメインソケットを利用する方法
teratail - nginxで(111: Connection refused)エラーがでます。

環境

CentOS7
nginx
unicorn

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

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

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

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

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

guest

回答1

0

ベストアンサー

default.conf

upstream app_server { server unix:/var/www/RailsApp/current/tmp/sockets/.unicorn.sock; } server { ... location @app { ... proxy_pass http://127.0.0.1:3000; } ... }

upstreamをproxy_passで使ってないのが原因に見えました。

proxy_pass http://app_server;

って書くと大丈夫そうです。

投稿2018/05/10 14:44

set0gut1

総合スコア2413

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

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

ruby_0ct

2018/05/10 15:53

ご回答ありがとうございます。 なるほど。そういう構造だったのですね。勉強になります。 無事にアクセスできました。ありがとうございました。
set0gut1

2018/05/10 16:01

おめでとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問