繁体   English   中英

使用Capistrano部署Rails应用程序时出现问题

[英]Problems deploying rails app with Capistrano

我正在使用capistrano将rails 3.2.16应用程序部署到VPS服务器。 这是我使用capistrano的时间,所以考虑我是新手。 我在运行“ cap deploy:update”时遇到问题,不确定从这里开始做什么。

以下是发生的情况的终端输出:

    ******-MBP:Folio stevo$ bundle exec cap deploy:update
    triggering load callbacks
  * 2013-12-26 20:29:21 executing `deploy:update'
 ** transaction: start
  * 2013-12-26 20:29:21 executing `deploy:update_code'
    updating the cached checkout on all servers
    executing locally: "git ls-remote git@bitbucket.org:**********/*********.git master-staging"
    command finished in 1626ms
  * executing "if [ -d /home/********/app/*********/shared/cached-copy ]; then cd /home/********/app/*********/shared/cached-copy && git fetch -q origin && git fetch --tags -q origin && git reset -q --hard c56df1b37c96846177a518133e89c1188b8d7a09 && git clean -q -d -x -f; else git clone -q -b master-staging git@bitbucket.org:**********/*********.git /home/********/app/*********/shared/cached-copy && cd /home/********/app/*********/shared/cached-copy && git checkout -q -b deploy c56df1b37c96846177a518133e89c1188b8d7a09; fi"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 3002ms
    copying the cached version to /home/********/app/*********/releases/20131227002927
  * executing "cp -RPp /home/********/app/*********/shared/cached-copy /home/********/app/*********/releases/20131227002927 && (echo c56df1b37c96846177a518133e89c1188b8d7a09 > /home/********/app/*********/releases/20131227002927/REVISION)"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 1025ms
  * 2013-12-26 20:29:28 executing `deploy:finalize_update'
    triggering before callbacks for `deploy:finalize_update'
  * 2013-12-26 20:29:28 executing `deploy:assets:symlink'
  * executing "rm -rf /home/********/app/*********/releases/20131227002927/public/assets && mkdir -p /home/********/app/*********/releases/20131227002927/public && mkdir -p /home/********/app/*********/shared/assets && ln -s /home/********/app/*********/shared/assets /home/********/app/*********/releases/20131227002927/public/assets"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 911ms
  * 2013-12-26 20:29:29 executing `bundle:install'
  * executing "cd /home/********/app/*********/releases/20131227002927 && bundle install --gemfile /home/********/app/*********/releases/20131227002927/Gemfile --path /home/********/app/*********/shared/bundle --deployment --quiet --without development test"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 1533ms
  * executing "chmod -R -- g+w /home/********/app/*********/releases/20131227002927 && rm -rf -- /home/********/app/*********/releases/20131227002927/public/system && mkdir -p -- /home/********/app/*********/releases/20131227002927/public/ && ln -s -- /home/********/app/*********/shared/system /home/********/app/*********/releases/20131227002927/public/system && rm -rf -- /home/********/app/*********/releases/20131227002927/log && ln -s -- /home/********/app/*********/shared/log /home/********/app/*********/releases/20131227002927/log && rm -rf -- /home/********/app/*********/releases/20131227002927/tmp/pids && mkdir -p -- /home/********/app/*********/releases/20131227002927/tmp/ && ln -s -- /home/********/app/*********/shared/pids /home/********/app/*********/releases/20131227002927/tmp/pids && rm -rf -- /home/********/app/*********/releases/20131227002927/config/application.yml && mkdir -p -- /home/********/app/*********/releases/20131227002927/config/ && ln -s -- /home/********/app/*********/shared/application.yml /home/********/app/*********/releases/20131227002927/config/application.yml"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 940ms
    triggering after callbacks for `deploy:update_code'
  * 2013-12-26 20:29:32 executing `deploy:assets:precompile'
    triggering before callbacks for `deploy:assets:precompile'
  * 2013-12-26 20:29:32 executing `deploy:assets:update_asset_mtimes'
  * executing "[ -e /home/********/app/*********/shared/assets/manifest* ] && cat /home/********/app/*********/shared/assets/manifest* || echo"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 903ms
  * executing "cat /home/********/app/*********/current/REVISION"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 920ms
*** [deploy:update_code] rolling back
  * executing "rm -rf /home/********/app/*********/releases/20131227002927; true"
    servers: ["198.**.***.***"]
    [198.**.***.***] executing command
    command finished in 918ms
failed: "rvm_path=$HOME/.rvm $HOME/.rvm/bin/rvm-shell 'default' -c 'cat /home/********/app/*********/current/REVISION'" on 198.**.***.***

如果问题出在这里,这是我的deploy.rb文件:

server '198.**.***.***', :web, :app, :db, primary: true

set :application, '*********'
set :user, '*********'
set :deploy_to, "/home/#{user}/app/#{application}"
set :deploy_via, :remote_cache
set :use_sudo, false

set :rvm_type, :user

set :scm, 'git'
set :repository, "git@bitbucket.org:*****/#{application}.git"
set :branch, `git rev-parse --abbrev-ref HEAD`.strip

set :shared_children, shared_children + %w{ config/application.yml }

default_run_options[:pty] = true
ssh_options[:forward_agent] = true

# Using Passenger
namespace :deploy do
  task :start do ; end
  task :stop do ; end
  task :restart, :roles => :app, :except => { :no_release => true } do
    run "#{try_sudo} touch #{File.join(current_path,'tmp','restart.txt')}"
  end
end


# Skipping Asset Compilation With Capistrano
# http://www.bencurtis.com/2011/12/skipping-asset-compilation-with-capistrano/
namespace :deploy do
  namespace :assets do
    task :precompile, :roles => :web, :except => { :no_release => true } do
      from = source.next_revision(current_revision)
      if capture("cd #{latest_release} && #{source.local.log(from)} vendor/assets/ app/assets/ | wc -l").to_i > 0
        run %Q{cd #{latest_release} && #{rake} RAILS_ENV=#{rails_env} #{asset_env} assets:precompile}
      else
        logger.info "Skipping asset pre-compilation because there were no asset changes"
      end
    end
  end
end

require "rvm/capistrano"
require "bundler/capistrano"

我究竟做错了什么?

您的cap部署在deploy:assets:precompile任务中抛出了错误,该任务已在deploy.rb中覆盖,请在注释deploy.rb中的以下给定代码后尝试运行cap deploy

namespace :deploy do

  namespace :assets do

  task :precompile, :roles => :web, :except => { :no_release => true } do
    from = source.next_revision(current_revision)
    if capture("cd #{latest_release} && #{source.local.log(from)} vendor/assets/  app/assets/ | wc -l").to_i > 0
    run %Q{cd #{latest_release} && #{rake} RAILS_ENV=#{rails_env} #{asset_env} assets:precompile}
    else
      logger.info "Skipping asset pre-compilation because there were no asset changes"
    end
  end
end

结束

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM