我正在尝试运行cap depoly,我收到以下错误
command finished in 881ms
* 2013-01-24 12:50:53 executing `whenever:update_crontab'
* executing "cd /home/deployer/apps/cf/releases/20130124115051 && bundle exec whenever --update-crontab cf --set environment=production --roles db"
servers: ["208.68.37.172"]
[208.68.37.172] executing command
** [out :: 208.68.37.172] Could not find acts-as-taggable-on-2.3.3 in any of the sources
** [out :: 208.68.37.172]
** [out :: 208.68.37.172] Run `bundle install` to install missing gems.
** [out :: 208.68.37.172]
command finished in 1957ms
*** [deploy:update_code] rolling back
* executing "rm -rf /home/deployer/apps/cf/releases/20130124115051; true"
servers: ["208.68.37.172"]
[208.68.37.172] executing command
command finished in 935ms
failed: "sh -c 'cd /home/deployer/apps/cf/releases/20130124115051 && bundle exec whenever --update-crontab cf --set environment=production --roles db'" on 208.68.37.172
我后来意识到,在将rails应用程序升级到最新版本的rails之后,捆绑程序在命令之前没有运行。 3.2.11。任何帮助谢谢。
set :whenever_command, "bundle exec whenever"
require "bundler/capistrano"
require "whenever/capistrano"
server "208.68.37.172", :web, :app, :db, primary: true
set :application, "xx"
set :user, "deployer"
set :deploy_to, "/home/#{user}/apps/#{application}"
set :deploy_via, :remote_cache
set :use_sudo, false
set :scm, "git"
set :repository, "git@github.com:ramza1/#{application}.git"
set :branch, "master"
default_run_options[:pty] = true
ssh_options[:forward_agent] = true
after "deploy", "deploy:cleanup" # keep only the last 5 releases
namespace :deploy do
%w[start stop restart].each do |command|
desc "#{command} unicorn server"
task command, roles: :app, except: {no_release: true} do
run "/etc/init.d/unicorn_#{application} #{command}"
end
end
task :setup_config, roles: :app do
sudo "ln -nfs #{current_path}/config/nginx.conf /etc/nginx/sites-enabled/#{application}"
sudo "ln -nfs #{current_path}/config/unicorn_init.sh /etc/init.d/unicorn_#{application}"
run "mkdir -p #{shared_path}/config"
put File.read("config/database.example.yml"), "#{shared_path}/config/database.yml"
puts "Now edit the config files in #{shared_path}."
end
after "deploy:setup", "deploy:setup_config"
task :symlink_config, roles: :app do
run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml"
end
after "deploy:finalize_update", "deploy:symlink_config"
after "deploy:update_code" do
run "mkdir -p #{release_path}/ckeditor_assets"
run "ln -nfs #{shared_path}/ckeditor_assets #{release_path}/public/ckeditor_assets"
end
desc "Make sure local git is in sync with remote."
task :check_revision, roles: :web 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
before "deploy", "deploy:check_revision"
end
答案 0 :(得分:1)
我认为你的问题都是:
首先,在您的deploy.rb
食谱上添加下一个文件的顶部:
require "bundler/capistrano"
require "whenever/capistrano"
第二个我认为你必须从你的gem文件中安装:
gem 'acts-as-taggable-on'
第三个问题是版本whenever 0.8.2
上的版本随部署失败。卸载0.8.2版并安装例如whenever (0.7.3)
卸载acts-as-taggable-on-2.3.3
并检查是否在没有该gem的情况下部署正在运行。
另外我使用rbenv
并且在我的bash_profile之前我有任何其他$ PATH声明,以确保它首先抓取那些可执行文件:
export PATH="$HOME/.rbenv/bin:$PATH"
从set :whenever_command, "bundle exec whenever"
顶部删除,并在set :branch, "master"
请尝试以下步骤查看是否有效
问候!
答案 1 :(得分:0)
从日志中看起来似乎缺少行为标签
安装act-as-taggable-on
Gemfile 上的 gem 'acts-as-taggable-on'
或去那里找到这个宝石的具体版本 https://rubygems.org/gems/acts-as-taggable-on
答案 2 :(得分:0)
尝试:
从终端
键入以下内容 crontab -e
这将打开crontab进行编辑。
现在您将看到如下两行:
PATH=/<path to bundle>/bundle/ruby/1.9.1/bin:/usr/local/rvm/gems
和
PATH=/<path to bundle>/shared/bundle/ruby/1.9.1/bin:/usr/local/rvm/gems
注释掉以PATH开头的两行。
每次运行bundle exec whenever
命令时都执行上述步骤。它有效。