2016-10-01 3 views
5

私はCapistrano経由でサーバーにRailsアプリケーションを配備しようとしました。 は、これは私が走った、すべてがスムーズに自分のサイトが正常に展開することができます動作しますが、私はそれの後にメッセージを得た「キャップ生産が展開」deploy.rb`` puma:restart 'は2回呼びますが、私はCapistranoを介して私の展開アプリで一度だけ呼びますか?

set :repo_url,  '[email protected]:varisdaOfficial/insurance_site.git' 
set :application,  'insurance_code' 
set :user,   'deploy' 
set :puma_threads, [4, 16] 
set :puma_workers, 0 

set :pty,    true 
set :use_sudo,  false 
set :stage,   :production 
set :deploy_via,  :remote_cache 
set :deploy_to,  "/home/#{fetch(:user)}/apps/#{fetch(:application)}" 
set :puma_bind,  "unix://#{shared_path}/tmp/sockets/#{fetch(:application)}-puma.sock" 
set :puma_state,  "#{shared_path}/tmp/pids/puma.state" 
set :puma_pid,  "#{shared_path}/tmp/pids/puma.pid" 
set :puma_access_log, "#{release_path}/log/puma.error.log" 
set :puma_error_log, "#{release_path}/log/puma.access.log" 
set :ssh_options,  { forward_agent: true, user: fetch(:user), keys: %w(~/.ssh/id_rsa.pub) } 
set :puma_preload_app, true 
set :puma_worker_timeout, nil 
set :puma_init_active_record, true # Change to false when not using ActiveRecord 
set :linked_dirs, %w(public/uploads) 

namespace :puma do 
    desc 'Create Directories for Puma Pids and Socket' 
    task :make_dirs do 
    on roles(:app) do 
     execute "mkdir #{shared_path}/tmp/sockets -p" 
     execute "mkdir #{shared_path}/tmp/pids -p" 
    end 
    end 

    before :start, :make_dirs 
end 

namespace :deploy do 
    desc "Make sure local git is in sync with remote." 
    task :check_revision do 
    on roles(:app) 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 
    end 

    desc 'Initial Deploy' 
    task :initial do 
    on roles(:app) do 
     before 'deploy:restart', 'puma:start' 
     invoke 'deploy' 
    end 
    end 

    desc 'Restart application' 
    task :restart do 
    on roles(:app), in: :sequence, wait: 5 do 
     invoke 'puma:restart' 
    end 
    end 

    desc 'clear temp cache' 
    task :clear_cache do 
    on roles(:app) , in: :sequence, wait: 1 do 
     execute "rm -rf #{shared_path}/tmp/cache/[^.]*" 

    end 
    end 

    before :starting,  :check_revision 
    after :finishing, :compile_assets 
    after :finishing, :cleanup 
    after :finishing, :clear_cache 
    after :finishing, :restart 
end 

に私のコードです。

Capistrano tasks may only be invoked once. Since task `puma:restart' was previously invoked, 
invoke("puma:restart") at/Users/manjarb/.rbenv/versions/2.2.3/lib/ruby/gems/2.2.0/gems/capistrano3-puma-1.2.1/lib/capistrano/tasks/puma.rake:134 will be skipped. 
If you really meant to run this task again, first call Rake::Task["puma:restart"].reenable 
THIS BEHAVIOR MAY CHANGE IN A FUTURE VERSION OF CAPISTRANO. Please join the conversation here if this affects you. 
https://github.com/capistrano/capistrano/issues/1686 

ただ再起動タスクを1回呼び出すだけです。 どうすればこのメッセージを修正できますか?

ありがとうございます!

答えて

15

あなたはcapistrano3-puma gemを使用していると仮定します。その宝石は、成功した展開の終わりにあなたのために自動的にプーマを再起動します。再起動タスクが呼び出されるのはこれが初めてです。

また、deploy.rbでは独自のカスタム再起動タスクを定義しており、それを呼び出すのはafter :finishingです。これが2回目の呼び出しのソース、したがって警告です。

、この問題を "解決" 冗長タスク削除するには:

desc 'Restart application' 
task :restart do 
    on roles(:app), in: :sequence, wait: 5 do 
    invoke 'puma:restart' 
    end 
end 

をそして、この削除:

after :finishing, :restart 
+1

をマットの答えは正しいものです。しかし、カピストラノのタスクを2回実行する必要がある人にとっては、呼び出しを使ってタスクを呼び出すことができます!代わりに。 –

関連する問題