Capistrano выдает /usr/bin/env: ruby: Нет такого файла или каталога при выполнении cap deploy

Я пытаюсь развернуть mailman с демоном и capistrano для моего приложения rails в рабочей среде, но получаю эту ошибку на своем локальном компьютере:

SSHKit::Runner::ExecuteError: Exception while executing on host 173.63.11.34: Exception while executing on host 178.62.16.69: script/mailman_daemon.rb exit status: 127
script/mailman_daemon.rb stdout: Nothing written
script/mailman_daemon.rb stderr: /usr/bin/env: ruby: No such file or directory

Ниже мой файл deploy.rb:

server '173.63.11.34', port: 22, roles: [:web, :app, :db], primary: true

set :repo_url,        '[email protected]:ryzalyusoff/xxxx.git'
set :application,     'xxxx'
set :user,            'deploy'
set :puma_threads,    [4, 16]
set :puma_workers,    0

set :pty,             false
set :use_sudo,        false
set :stage,           :production
set :deploy_via,      :remote_cache
set :deploy_to,       "/home/#{fetch(:user)}/apps/#{fetch(:application)}"
set :puma_bind,       "unix://#{shared_path}/tmp/sockets/#{fetch(:application)}-puma.sock"
set :puma_state,      "#{shared_path}/tmp/pids/puma.state"
set :puma_pid,        "#{shared_path}/tmp/pids/puma.pid"
set :puma_access_log, "#{release_path}/log/puma.error.log"
set :puma_error_log,  "#{release_path}/log/puma.access.log"
set :ssh_options,     { forward_agent: true, user: fetch(:user), keys: %w(~/.ssh/id_rsa.pub) }
set :puma_preload_app, true
set :puma_worker_timeout, nil
set :puma_init_active_record, true  # Change to false when not using ActiveRecord


set :whenever_identifier, ->{ "myapp_#{fetch(:stage)}" }

namespace :puma do
  desc 'Create Directories for Puma Pids and Socket'
  task :make_dirs do
    on roles(:app) do
      execute "mkdir #{shared_path}/tmp/sockets -p"
      execute "mkdir #{shared_path}/tmp/pids -p"
    end
  end

  before :start, :make_dirs
end

namespace :deploy do
  desc "Make sure local git is in sync with remote."
  task :check_revision do
    on roles(:app) do
      unless `git rev-parse HEAD` == `git rev-parse origin/master`
        puts "WARNING: HEAD is not the same as origin/master"
        puts "Run `git push` to sync changes."
        exit
      end
    end
  end

  desc 'Initial Deploy'
  task :initial do
    on roles(:app) do
      before 'deploy:restart', 'puma:start'
      invoke 'deploy'
    end
  end

  desc 'Restart application'
  task :restart do
    on roles(:app), in: :sequence, wait: 5 do
      invoke 'puma:restart'
    end
  end

  before :starting,     :check_revision
  after  :finishing,    :compile_assets
  after  :finishing,    :cleanup
  after  :finishing,    :restart

end


# Mailman configuration
namespace :mailman do
  desc "Mailman::Start"
  task :start do
    on roles(:app) do
      within release_path do
        with default_env: fetch(:default_env) do
          execute "script/mailman_daemon.rb", "start"
        end
      end
    end
  end

  desc "Mailman::Stop"
  task :stop do
    on roles(:app) do
      within release_path do
        with default_env: fetch(:default_env) do
          execute "script/mailman_daemon.rb", "stop"
        end
      end
    end
  end

  desc "Mailman::Restart"
  task :restart do
    on roles(:app) do
      invoke("mailman:stop")
      invoke("mailman:start")
    end
  end
end

before "deploy:cleanup", "mailman:restart"

И ниже мой гемфайл:

source 'https://rubygems.org'

ruby "2.0.0"

gem 'rails', '4.2.3'
gem 'mysql2', '~> 0.3.18'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.1.0'
gem 'jquery-rails'
gem 'turbolinks'
gem 'jbuilder', '~> 2.0'
gem 'sdoc', '~> 0.4.0', group: :doc

group :development, :test do
  gem 'byebug'
  gem 'web-console', '~> 2.0'
  gem "rails-erd"
  gem 'capistrano',           require: false
  gem 'capistrano-rvm',       require: false
  gem 'capistrano-rails',     require: false
  gem 'capistrano-bundler',   require: false
  gem 'capistrano3-puma',     require: false
  gem 'rvm1-capistrano3', require: false
end

group :production do
  gem 'rails_12factor', '0.0.2'
  gem 'thin'
  gem 'puma', '3.1.0'
end

gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
gem 'bootstrap-sass', '~> 3.3.4.1'
gem "better_errors"
gem "devise"
gem 'rails_admin', '~> 0.6.8'
gem 'jquery-ui-rails'
gem 'execjs'
gem 'therubyracer', :platforms => :ruby
gem "compass-rails", github: "Compass/compass-rails", branch: "master"
gem 'sucker_punch', '~> 2.0', '>= 2.0.1'
gem 'carrierwave'
gem "fog-aws"

# Sending SMS
gem 'twilio-ruby'
gem 'postmark-rails', "~> 0.5.2"
# Cronjob
gem 'whenever', '~> 0.9.4'
gem 'griddler'
gem 'mailman'
gem 'email_reply_parser', '~> 0.5.8'
gem 'mail_extract', '~> 0.1.4'
gem 'daemons', '~> 1.2', '>= 1.2.3'
gem 'delayed_job_active_record'

Я использую capistrano (3.4.0) и capistrano-rvm (0.1.2).

И я попытался использовать гем rvm1-capistrano3 и rvm-capistrano, как это предлагается в этом thread, но не повезло.

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

Спасибо!

####################### ОБНОВЛЕНИЕ 1 #####################< /сильный>

Вот что у меня получилось git grep usr.bin.env на моей локальной машине:

bin/bundle:#!/usr/bin/env ruby.exe
bin/delayed_job:#!/usr/bin/env ruby
bin/rails:#!/usr/bin/env ruby.exe
bin/rake:#!/usr/bin/env ruby.exe
bin/setup:#!/usr/bin/env ruby.exe
script/mailman_daemon.rb:#!/usr/bin/env ruby
script/mailman_server:#!/usr/bin/env ruby

####################### ОБНОВЛЕНИЕ 2 #####################< /сильный>

Я уже установил путь для своего rvm в моем ~/.bash_profile:

export PATH="$PATH:$HOME/.rvm/bin" # Add RVM to PATH for scripting

[[ -s "$HOME/.profile" ]] && source "$HOME/.profile" # Load the default .profile

[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm" # Load RVM into a shell session *as a function*
~   

person Ryzal Yusoff    schedule 09.03.2016    source источник
comment
Если вы сделаете git grep usr.bin.env, что вы получите?   -  person Andrew Grimm    schedule 10.03.2016
comment
Где я могу ввести это? В любом случае, я набрал это в текущем каталоге моего производственного сервера и получил следующее: fatal: Not a git repository (or any of the parent directories): .git   -  person Ryzal Yusoff    schedule 10.03.2016
comment
На вашей машине разработки. (Почему вы не набрали его на своей машине для разработки, прежде чем спросить?)   -  person Andrew Grimm    schedule 10.03.2016
comment
О, извините, мой плохой ... Я поставил результат на свой первоначальный вопрос выше.   -  person Ryzal Yusoff    schedule 10.03.2016
comment
Вы получили решение?   -  person Dusht    schedule 04.03.2017


Ответы (2)


Похоже, что пользователь deploy на 173.63.11.34 не имеет доступа к исполняемому файлу ruby.

Убедитесь, что вы устанавливаете ruby, rvm и др. в контексте пользователя deploy или в глобальной области 173.63.11.34.

Один из способов проверить это ssh войти в 173.63.11.34 как пользователь deploy и посмотреть, сможете ли вы выполнить ruby или rvm и т. д.

person Dharam Gollapudi    schedule 09.03.2016
comment
Эй, спасибо за ответ, но я определенно установил ruby ​​и rvm в контексте пользователя deploy. Я попытался подключиться к серверу по ssh и протестировать ruby, как вы предложили, и он отлично работает. Я проверил это с помощью команды irb следующим образом: deploy@Myapp:~/apps/myapp/current$ irb - person Ryzal Yusoff; 10.03.2016

либо вы не установили свой rvm или rbenv, chruby или двоичный файл ruby ​​на свой рабочий сервер.

или, что более вероятно, вы неуместны или забыли добавить PATH и/или исходные скрипты, такие как

для РВМ

export PATH=$PATH:$HOME/.rvm/bin # Добавить RVM в PATH для сценариев

[[ -s $HOME/.rvm/scripts/rvm ]] && источник $HOME/.rvm/scripts/rvm

or

для рбенв

экспорт PATH=$PATH:$HOME/.rbenv/bin

eval $(rbenv инициализация - )

экспорт PATH=$PATH:$HOME/.rbenv/plugins/ruby-build/bin

or

для чрубых

источник /usr/share/chruby/chruby.sh

источник /usr/share/chruby/auto.sh

РУБИНЫ+=(/opt/рубины/*)

or

что-то подобное

person krazedkrish    schedule 18.03.2016
comment
Эй, у меня определенно установлен rvm на моем рабочем сервере, и я также уже установил его PATH в моем ~/.bash_profile. См. мое обновление 2 выше - person Ryzal Yusoff; 18.03.2016
comment
Какую оболочку вы получаете при входе в систему как развертывание в удаленной оболочке. Это ш баш сш. Попробуйте команду echo $SHELL, если это sh вместо bash, ваш .bash_profile не будет работать - person krazedkrish; 19.03.2016