[英]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.