.rvm / gems / ruby -2.6.5 / gems / puma-4.3.3 / lib / puma / binder.rb: 328: в `listen ': адрес уже используется - listen (2) (Errno :: EADDRINUSE ) - PullRequest
1 голос
/ 28 апреля 2020

Я изменился с Ma c на Linux (Ubuntu) пару дней go, и я клонировал репо из моего командного проекта в GitHub. (До этого он работал с Ма c). Но теперь у меня есть эта проблема.

Я пытался запустить сервер на локальном Unix сокете (3000), запустив

bundle exec puma

, но вместо этого он показывает эти ошибки.

[3217] Puma starting in cluster mode...
[3217] * Version 4.3.3 (ruby 2.6.5-p114), codename: Mysterious Traveller
[3217] * Min threads: 1, max threads: 16
[3217] * Environment: development
[3217] * Process workers: 1
[3217] * Preloading application
Traceback (most recent call last):
        13: from /home/shaun/.rvm/gems/ruby-2.6.5/bin/ruby_executable_hooks:24:in `<main>'
        12: from /home/shaun/.rvm/gems/ruby-2.6.5/bin/ruby_executable_hooks:24:in `eval'
        11: from /home/shaun/.rvm/gems/ruby-2.6.5/bin/puma:23:in `<main>'
        10: from /home/shaun/.rvm/gems/ruby-2.6.5/bin/puma:23:in `load'
         9: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/bin/puma:10:in `<top (required)>'
         8: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/cli.rb:80:in `run'
         7: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/launcher.rb:172:in `run'
         6: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/cluster.rb:413:in `run'
         5: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/runner.rb:161:in `load_and_bind'
         4: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/binder.rb:90:in `parse'
         3: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/binder.rb:90:in `each'
         2: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/binder.rb:151:in `block in parse'
         1: from /home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/binder.rb:328:in `add_unix_listener'
/home/shaun/.rvm/gems/ruby-2.6.5/gems/puma-4.3.3/lib/puma/binder.rb:328:in `listen': Address already in use - listen(2) (Errno::EADDRINUSE)

Затем я попытался запустить

bundle exec puma -C config/puma.rb -b tcp://127.0.0.1:3001

, но сервер сразу же не запускается.

[3263] Puma starting in cluster mode...
[3263] * Version 4.3.3 (ruby 2.6.5-p114), codename: Mysterious Traveller
[3263] * Min threads: 1, max threads: 16
[3263] * Environment: development
[3263] * Process workers: 1
[3263] * Preloading application
[3263] * Listening on tcp://127.0.0.1:3001
[3263] Use Ctrl-C to stop

Я также попробовал методы, приведенные в этом посте: Адрес уже используется - bind (2) (Errno :: EADDRINUSE)

Как

lsof -wni tcp:3000

, но мне не было показано, как убить процесс Pid.

Может кто-нибудь помочь?

Вот версии программного обеспечения, которые я использую:

  • Ubuntu 18.04 LTS
  • Ruby 2.6.5p114 (2019- 10-01, редакция 67812) [x86_64-linux]
  • версия Puma 4.3.3

Это код в config / puma.rb

# vars
app_dir = File.expand_path("../..", __FILE__)
shared_dir = "#{app_dir}/shared"

# Specifies the `environment` that Puma will run in.
environment ENV.fetch("RACK_ENV") { "production" }

# pidfile and state
pidfile "#{shared_dir}/pids/puma.pid"
state_path "#{shared_dir}/pids/puma.state"

# Threads for serving requests
threads 1, 16

# Workers (cpu cores)
workers ENV.fetch("WEB_CONCURRENCY") { 1 }
preload_app!

# Unix socket to for nginix reverse proxy
bind "unix://#{shared_dir}/sockets/puma.sock"

# Port for local server use
port ENV.fetch("PORT") { 3000 }

# Debugging
debug

# Logging
stdout_redirect "#{shared_dir}/log/puma.stdout.log", "#{shared_dir}/log/puma.stderr.log", true

activate_control_app

rackup "#{app_dir}/config.ru"

1 Ответ

0 голосов
/ 28 апреля 2020

Похоже, вы работаете с другой программой на порту 3000. Запустите lsof -i:3000 и остановите его, используя команду kill, если в команде есть какой-либо результат.

...