Nginx и Unicorn не работают из-за ошибки файла unicorn.sock - PullRequest
0 голосов
/ 16 июня 2020

Я впервые настраиваю VPS на upcloud. Я использую unicorn 5.5.5 с Nginx. Рельсы 4.2.8 и ruby 2.4.2. Моя служба Nginx работает нормально. Не показывает ошибок. Всякий раз, когда я запускаю службу единорога, я получаю эту ошибку. Я следовал этому руководству.

https://medium.com/@manishyadavv / how-to-deploy- ruby -on-rails-apps-on- aws -ec2-7ce55bb955fa

F, [2020-06-16T12:44:20.611895 #12683] FATAL -- : error adding listener addr=/tmp/unicorn.sock
/usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/socket_helper.rb:132:in `bind_listen': socket=/tmp/unicorn.sock specified but it is not a socket! (ArgumentError)
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/http_server.rb:243:in `listen'
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/http_server.rb:851:in `block in bind_new_listeners!'
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/http_server.rb:851:in `each'
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/http_server.rb:851:in `bind_new_listeners!'
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/lib/unicorn/http_server.rb:142:in `start'
        from /usr/share/rvm/gems/ruby-2.4.2/gems/unicorn-5.5.5/bin/unicorn:128:in `<top (required)>'
        from /usr/share/rvm/gems/ruby-2.4.2/bin/unicorn:23:in `load'
        from /usr/share/rvm/gems/ruby-2.4.2/bin/unicorn:23:in `<main>'
        from /usr/share/rvm/gems/ruby-2.4.2/bin/ruby_executable_hooks:24:in `eval'
        from /usr/share/rvm/gems/ruby-2.4.2/bin/ruby_executable_hooks:24:in `<main>'

Мой unicorn.sock файл пуст, извините, если это ошибка ладьи ie, но я застрял с этой проблемой уже 2 дня. Пожалуйста, помогите мне. Вот мой файл unicorn_repo в каталоге etc / init.d

#!/bin/sh
### BEGIN INIT INFO
# Provides:          unicorn
# Required-Start:    $all
# Required-Stop:     $all
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: starts the unicorn app server
# Description:       starts unicorn using start-stop-daemon
### END INIT INFO
set -e
USAGE="Usage: $0 <start|stop|restart|upgrade|rotate|force-stop>"
# app settings
USER="root"
APP_NAME="soup"
APP_ROOT="/$USER/$APP_NAME"
ENV="production"
# environment settings
PATH="/home/$USER/.rbenv/shims:/home/$USER/.rbenv/bin:$PATH"
CMD="cd $APP_ROOT && bundle exec unicorn -c config/unicorn.rb -E $ENV -D"
PID="$APP_ROOT/shared/pids/unicorn.pid"
OLD_PID="$PID.oldbin"

вот мой файл nginx / default

upstream app {
    # Path to Unicorn SOCK file, as defined previously
    server unix:/tmp/unicorn.sock fail_timeout=0;
}
server {
    listen 0.0.0.0;
    server_name localhost;
    root root/soup/;
    try_files $uri/index.html $uri @app;
    location @app {
        proxy_pass http://app;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_redirect off;
    }
    error_page 500 502 503 504 /500.html;
    client_max_body_size 4G;
    keepalive_timeout 10;
}

Вот мой файл unicorn.rb.

# set path to application
app_dir = File.expand_path("../..", __FILE__)
shared_dir = "#{app_dir}/shared"
working_directory app_dir
# Set unicorn options
worker_processes 2
preload_app true
timeout 30
# Set up socket location
listen "/tmp/unicorn.sock", :backlog => 64
listen 3000, :tcp_nopush => true

# Logging
stderr_path "#{shared_dir}/log/unicorn.stderr.log"
stdout_path "#{shared_dir}/log/unicorn.stdout.log"
# Set master PID location
pid "#{shared_dir}/pids/unicorn.pid"
~
~
~
~

1 Ответ

1 голос
/ 17 июня 2020

A socket - это особый вид файла, используемый для взаимодействия между процессами. Если вы запускаете ls -la сокеты имеют в начале строки режима s.

Ваш должен выглядеть примерно так:

srwxrwxrwx /tmp/unicorn.sock

Если вы создали /tmp/unicorn.sock как файл вручную, удалите его.

В качестве примечания: используемому вами руководству 3 года, поэтому ваша установка устарела с самого начала.

...