実現したいこと
現在、AWSを用いてデプロイの練習をしております。こちらのサイト通りに進めており、⑤ページまで進めたのですがUnicornが起動できず以下のエラーで詰まっております。
発生している問題・エラーメッセージ
[app_name@ip-**-*-*-*** app_name]$ bundle exec unicorn_rails -c /var/www/projects/app_name/config/unicorn.conf.rb -D -E production master failed to start, check stderr log for details
該当のソースコード
Nginxの設定 sudo vi /etc/nginx/conf.d/app_name.conf
upstream unicorn_server { server unix:/var/www/projects/app_name/tmp/sockets/.unicorn.sock fail_timeout=0; } server { listen 80; client_max_body_size 4G; server_name IPアドレス; keepalive_timeout 5; # Location of our static files root /var/www/projects/app_name/public; location ~ ^/assets/ { root /var/www/projects/app_name/public; } location / { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; if (!-f $request_filename) { proxy_pass http://unicorn_server; break; } } error_page 500 502 503 504 /500.html; location = /500.html { root /var/www/projects/app_name/public; } }
Unicornの設定 vim config/unicorn.conf.rb
# set lets $worker = 2 $timeout = 30 $app_dir = "/var/www/projects/app_name" $listen = File.expand_path 'tmp/sockets/.unicorn.sock', $app_dir $pid = File.expand_path 'tmp/pids/unicorn.pid', $app_dir $std_log = File.expand_path 'log/unicorn.log', $app_dir # set config worker_processes $worker working_directory $app_dir stderr_path $std_log stdout_path $std_log timeout $timeout listen $listen pid $pid # loading booster preload_app true # before starting processes 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 Process.kill "QUIT", File.read(old_pid).to_i rescue Errno::ENOENT, Errno::ESRCH end end end # after finishing processes after_fork do |server, worker| defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection end
試したこと
Unicornのバージョンを5.4.1が良いという記事を見つけたのですが、解決できませんでした。
補足情報(FW/ツールのバージョンなど)
Ruby2.6.4
Rails5.2.3
Unicorn5.4.1
Mysql2 5.7
回答1件
あなたの回答
tips
プレビュー