簡體   English   中英

Capistrano無法安裝

[英]Capistrano doesn't install

每當我嘗試運行cap production deploy它都會在以下命令中失敗

[ebbf9fde] Command: cd /var/www/apps/my_app/releases/20150803171251 && /usr/local/rvm/bin/rvm 2.2.2 do bundle install --path /var/www/apps/my_app/shared/bundle --without development test --deployment --quiet
DEBUG [ebbf9fde]    /usr/local/rvm/scripts/set: line 19: exec: bundle: not found

我添加了一個用戶'deploy'來執行此部署, rvm list的輸出是

$ rvm list

rvm rubies

=* ruby-2.2.2 [ x86_64 ]

# => - current
# =* - current && default
#  * - default

進一步運行gem列表的輸出是

$ gem list

*** LOCAL GEMS ***

bigdecimal (1.2.6)
bundler-unload (1.0.2)
executable-hooks (1.3.2)
gem-wrappers (1.2.7)
io-console (0.4.3)
json (1.8.1)
minitest (5.4.3)
passenger (5.0.15)
power_assert (0.2.2)
psych (2.0.8)
rack (1.6.4)
rake (10.4.2)
rdoc (4.2.0)
rubygems-bundler (1.4.4)
rvm (1.11.3.9)
test-unit (3.0.8)

我的Capfile內容是

require 'capistrano/setup'
require 'capistrano/deploy'
require 'capistrano/rvm'
require 'capistrano/bundler'
require 'capistrano/rails/assets'
require 'capistrano/rails/migrations'

Dir.glob('lib/capistrano/tasks/*.rake').each { |r| import r }

最后,我的deploy.rb包含以下數據。

lock '3.4.0'

set :app_host, 'ip-address-here'
set :application, 'my_app'
set :repo_url, 'git@example.com:<not_right>/my_app.git'

set :rvm_type, :system
set :rvm_ruby_version, '2.2.2'
set :passenger_rvm_ruby_version, '2.2.2'
set :rbenv_ruby, '2.2.2'

set :deploy_to, '/var/www/apps/my_app'

set :scm, :git

set :format, :pretty

set :log_level, :debug

set :pty, true

set :conditionally_migrate, true

set :linked_dirs, fetch(:linked_dirs, []).push('log', 'tmp/pids', 'tmp/cache', 'tmp/sockets', 'vendor/bundle', 'public/system')

set :keep_releases, 5

set :migrate_env, "#{ fetch(:stage) }"


namespace :deploy do
  desc 'Restart application'
  task :restart do
    on roles(:web), in: :sequence, wait: 5 do
      execute :mkdir, '-p', release_path.join('tmp')
      execute :touch, release_path.join('tmp/restart.txt')
    end
  end

  task :httpd_graceful do
    on roles(:web), in: :sequence, wait: 5 do
      execute :sudo, "service httpd graceful"
    end
  end

  after :publishing, :restart
  after :restart, :clear_cache do
    on roles(:web), in: :groups, limit: 3, wait: 10 do
      # Here we can do anything such as:
      # within release_path do
      #   execute :rake, 'cache:clear'
      # end
    end
  end
end


namespace :deploy_prepare do
  desc 'Configure virtual host'
  task :create_vhost do
    on roles(:web), in: :sequence, wait: 5 do
    vhost_redirect_config = <<-EOF
Redirect permanent /#{ fetch(:application) } http://#{ fetch(:app_host) }/#{ fetch(:application) }/
    EOF

    vhost_location_config = <<-EOF
Alias /#{fetch(:application)} #{fetch(:deploy_to)}/current/public

<Location /#{fetch(:application)}>
   PassengerBaseURI /#{ fetch(:application) }
   PassengerAppRoot #{ fetch(:deploy_to) }/current/
   PassengerRuby /usr/local/rvm/wrappers/ruby-#{ fetch(:rvm_ruby_version) }/ruby
   RailsEnv #{ fetch(:stage) }
</Location>

<Directory #{ fetch(:deploy_to) }/current/public >
  Allow from all
  Options -MultiViews
</Directory>
    EOF
    execute :echo, "\"#{ vhost_redirect_config }\"", ">", "/etc/httpd/conf.d/redirects/#{ fetch(:application) }.conf"
    execute :echo, "\"#{ vhost_location_config }\"", ">", "/etc/httpd/conf.d/apps/#{ fetch(:application) }.conf"
  end
end
end

after "deploy:updated", "deploy:cleanup"
after "deploy:finished", "deploy_prepare:create_vhost"
after "deploy_prepare:create_vhost", "deploy:httpd_graceful"
after "deploy:httpd_graceful", "deploy:restart"

我收到以下錯誤

DEBUG [298e6d4e] Command: cd /var/www/apps/oxygen/releases/20150803172155 && /usr/local/rvm/bin/rvm 2.2.2 do bundle install --path /var/www/apps/oxygen/shared/bundle --without development test --deployment --quiet
DEBUG [298e6d4e]    /usr/local/rvm/scripts/set: line 19: exec: bundle: not found
(Backtrace restricted to imported tasks)
cap aborted!
SSHKit::Runner::ExecuteError: Exception while executing as deployer@162.243.131.67: bundle exit status: 127
bundle stdout: /usr/local/rvm/scripts/set: line 19: exec: bundle: not found
bundle stderr: Nothing written

SSHKit::Command::Failed: bundle exit status: 127
bundle stdout: /usr/local/rvm/scripts/set: line 19: exec: bundle: not found
bundle stderr: Nothing written

Tasks: TOP => deploy:updated => bundler:install
(See full trace by running task with --trace)
The deploy has failed with an error: Exception while executing as deployer@162.243.131.67: bundle exit status: 127
bundle stdout: /usr/local/rvm/scripts/set: line 19: exec: bundle: not found
bundle stderr: Nothing written

只需在服務器上嘗試gem install bundler一次就可以將bundle裝入rvm gemset,因為它不在你的gem list

通常,嘗試確保在通過ssh登錄服務器時運行bundle命令。 Capistrano不做魔術,它只是通過ssh登錄並發出命令。 你可以隨時查看capistrano發出的命令,比如你的例子cd /var/www/apps/oxygen/releases/20150803172155 && /usr/local/rvm/bin/rvm 2.2.2 do bundle install --path /var/www/apps/oxygen/shared/bundle --without development test --deployment --quiet並在出現故障時自己嘗試。

確保在正確的gemset中安裝了bundler。

我收到了這個錯誤,並且因為捆綁器安裝在默認的gemset中而感到頭疼,但它不是我用於我的rails應用程序的那個。

當我意識到它時,我就像,“哇!”

只是想我會在這里發布,希望它會幫助別人。

這對我來說不起作用, gem install bundler

我意識到我沒有正確設置deploy.rb文件。

因為我使用RVM,我檢查了rvm list中的ruby版本

   jruby-1.7.19 [ x86_64 ]
=* ruby-2.2.1 [ x86_64 ]

然后配置我的deploy.rb文件set :rvm_ruby_version, 'ruby-2.2.1'

在您的服務器上

rvm 2.2.2@gemset-name do gem install bundler

資料來源: https//github.com/capistrano/rvm/issues/65#issuecomment-94108188

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM