前提・実現したいこと
取得したドメインにアクセスできるようにしたい
発生している問題・エラーメッセージ
connect() to unix:/var/www/【アプリ名】/tmp/sockets/unicorn.sock failed (111: Connection refused) while connecting to upstream, client: 【CLIENT IP】, server: 【ドメイン名】, request: "GET / HTTP/1.1", upstream: "http://unix:/var/www/【アプリ名】/tmp/sockets/unicorn.sock:/", host: 【アプリ IP】
ブラウザ側
”このサイトにアクセスできません”
該当のソースコード
/etc/nginx/conf.d/rails.conf
upstream app_server { server unix:/var/www/【アプリ名】/shared/tmp/sockets/unicorn.sock; } server { listen 80; server_name 【ドメイン名】; client_max_body_size 2g; root /var/www/【アプリ名】/current/public; location ^~ /assets/ { gzip_static on; expires max; add_header Cache-Control public; root /var/www/【アプリ名】/current/public; } try_files $uri/index.html $uri @unicorn; location @unicorn { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://app_server; } error_page 500 502 503 504 /500.html; }
原因 ??
エラーメッセージのパスとrails.confのupstreamのserverのパスが違うからではないか
→ 適用されてないからでは無いかと思い、reloadしてrestart
補足情報(FW/ツールのバージョンなど)
ruby: 2.6.6
Rails: 6.0.0
nginx
ec2
unicorn
capistrano
- リストIPアドレスからはアクセスできる
$ dig 【ドメイン名】 # => 正しく出力される
- config/unicorn.rb
ruby
1app_path = File.expand_path('../../../', __FILE__) 2 3worker_processes 1 4 5working_directory "#{app_path}/current" 6 7pid "#{app_path}/shared/tmp/pids/unicorn.pid" 8 9listen "#{app_path}/shared/tmp/sockets/unicorn.sock" 10 11stderr_path "#{app_path}/shared/log/unicorn.stderr.log" 12 13stdout_path "#{app_path}/shared/log/unicorn.stdout.log" 14 15 16timeout 60 17 18preload_app true 19GC.respond_to?(:copy_on_write_friendly=) && GC.copy_on_write_friendly = true 20 21check_client_connection false 22 23run_once = true 24 25before_fork do |server, worker| 26 defined?(ActiveRecord::Base) && 27 ActiveRecord::Base.connection.disconnect! 28 29 if run_once 30 run_once = false # prevent from firing again 31 end 32 33 old_pid = "#{server.config[:pid]}.oldbin" 34 if File.exist?(old_pid) && server.pid != old_pid 35 begin 36 sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU 37 Process.kill(sig, File.read(old_pid).to_i) 38 rescue Errno::ENOENT, Errno::ESRCH => e 39 logger.error e 40 end 41 end 42end 43 44after_fork do |_server, _worker| 45 defined?(ActiveRecord::Base) && ActiveRecord::Base.establish_connection 46end