Пакет не работает раньше, когда в Cap развертывания

Я пытаюсь запустить 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 

3 ответа

Решение

Я думаю, что ваши проблемы оба:

Первое, на вашем 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 и проверьте, работает ли без этого драгоценного камня развертывание.

Также я использую rbenv и у меня есть это в моем bash_profile перед любыми другими объявлениями $PATH, чтобы убедиться, что он сначала захватывает эти исполняемые файлы:

export PATH="$HOME/.rbenv/bin:$PATH"

Снять сверху set :whenever_command, "bundle exec whenever" и добавьте этот код после set :branch, "master"

Попробуйте эти шаги, чтобы увидеть, если это работает

С уважением!

Из журналов кажется, что действует-как-taggable-on отсутствует

Для установки актов-как-taggable-на

gem 'acts-as-taggable-on' на вашем Gemfile

или зайдите туда, чтобы найти конкретную версию этого драгоценного камня https://rubygems.org/gems/acts-as-taggable-on

Пытаться:

Введите следующее из терминала

 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 команда. И это работает.

Другие вопросы по тегам