lib/caploy/recipes/unicorn.rb in caploy-0.1.4 vs lib/caploy/recipes/unicorn.rb in caploy-0.1.5
- old
+ new
@@ -1,45 +1,147 @@
-Capistrano::Configuration.instance.load do
+require 'capistrano'
+require 'capistrano/version'
- _cset :unicorn_bin, "bundle exec unicorn"
- _cset :unicorn_pid, "#{deploy_to}/current/tmp/pids/unicorn.pid"
- _cset :unicorn_std_log, "log/unicorn.stderr.log"
- _cset :unicorn_err_log, "log/unicorn.stderr.log"
- _cset :unicorn_worker_processes, 2
- _cset :unicorn_listen_backlog, 2048
- _cset :sidekiq_redis_count, 1
+module Unicorn
+ class CapistranoIntegration
+ def self.load_into(capistrano_config)
+ capistrano_config.load do
- require "capistrano-unicorn"
+ # Check if remote file exists
+ #
+ def remote_file_exists?(full_path)
+ 'true' == capture("if [ -e #{full_path} ]; then echo 'true'; fi").strip
+ end
- namespace :unicorn do
- desc "Setup unicorn"
- task :setup, :roles => :app, :except => { :no_release => true } do
- run "mkdir -p \"#{shared_path}/config/unicorn\""
- config_path = "#{shared_path}/config/unicorn/#{rails_env}.rb"
- template_path = File.expand_path('../../templates/unicorn/unicorn.rb.erb', __FILE__)
- vars = {
- 'application'=> application,
- 'current_path' => current_path,
- 'unicorn_pid' => unicorn_pid,
- 'unicorn_std_log' => unicorn_std_log,
- 'unicorn_err_log' => unicorn_err_log,
- 'stage' => stage,
- 'unicorn_listen_backlog' => unicorn_listen_backlog,
- 'unicorn_worker_processes' => unicorn_worker_processes,
- 'sidekiq_redis_count' => sidekiq_redis_count
- }
- put(render_erb_template(template_path, vars), config_path)
- end
- end
+ # Check if process is running
+ #
+ def process_exists?(pid_file)
+ capture("ps -p $(cat #{pid_file}) ; true").strip.split("\n").size == 2
+ end
- after :"deploy:setup", :"unicorn:setup";
+ # Set unicorn vars
+ #
+ _cset(:app_env, (fetch(:rails_env) rescue 'production'))
+ _cset :unicorn_bin, "bundle exec unicorn"
+ _cset(:unicorn_pid, "#{fetch(:current_path)}/tmp/pids/unicorn.pid")
+ _cset(:unicorn_env, (fetch(:app_env)))
+ _cset :unicorn_std_log, "log/unicorn.stderr.log"
+ _cset :unicorn_err_log, "log/unicorn.stderr.log"
+ _cset :unicorn_worker_processes, 2
+ _cset :unicorn_listen_backlog, 2048
+ _cset :sidekiq_redis_count, 1
+ _cset :unicorn_hard_restart, false
- namespace :deploy do
- task :start, :roles => :app do
- unicorn.start
- end
+ namespace :unicorn do
+ desc 'Start Unicorn'
+ task :start, :roles => :app, :except => {:no_release => true} do
+ if remote_file_exists?(unicorn_pid)
+ if process_exists?(unicorn_pid)
+ logger.important("Unicorn is already running!", "Unicorn")
+ next
+ else
+ run "rm #{unicorn_pid}"
+ end
+ end
- task :stop, :roles => :app do
- unicorn.stop
+ config_path = "#{current_path}/config/unicorn/#{unicorn_env}.rb"
+ if remote_file_exists?(config_path)
+ logger.important("Starting...", "Unicorn")
+ run "cd #{current_path} && BUNDLE_GEMFILE=#{current_path}/Gemfile bundle exec #{unicorn_bin} -c #{config_path} -E #{app_env} -D"
+ else
+ logger.important("Config file for \"#{unicorn_env}\" environment was not found at \"#{config_path}\"", "Unicorn")
+ end
+ end
+
+ desc 'Stop Unicorn'
+ task :stop, :roles => :app, :except => {:no_release => true} do
+ if remote_file_exists?(unicorn_pid)
+ if process_exists?(unicorn_pid)
+ logger.important("Stopping...", "Unicorn")
+ run "#{try_sudo} kill `cat #{unicorn_pid}`"
+ else
+ run "rm #{unicorn_pid}"
+ logger.important("Unicorn is not running.", "Unicorn")
+ end
+ else
+ logger.important("No PIDs found. Check if unicorn is running.", "Unicorn")
+ end
+ end
+
+ desc 'Unicorn graceful shutdown'
+ task :graceful_stop, :roles => :app, :except => {:no_release => true} do
+ if remote_file_exists?(unicorn_pid)
+ if process_exists?(unicorn_pid)
+ logger.important("Stopping...", "Unicorn")
+ run "#{try_sudo} kill -s QUIT `cat #{unicorn_pid}`"
+ else
+ run "rm #{unicorn_pid}"
+ logger.important("Unicorn is not running.", "Unicorn")
+ end
+ else
+ logger.important("No PIDs found. Check if unicorn is running.", "Unicorn")
+ end
+ end
+
+ desc 'Reload Unicorn'
+ task :reload, :roles => :app, :except => {:no_release => true} do
+ if remote_file_exists?(unicorn_pid)
+ logger.important("Stopping...", "Unicorn")
+ if unicorn_hard_restart
+ unicorn.stop
+ sleep(2)
+ unicorn.start
+ else
+ run "#{try_sudo} kill -s USR2 `cat #{unicorn_pid}`"
+ end
+ else
+ logger.important("No PIDs found. Starting Unicorn server...", "Unicorn")
+ config_path = "#{current_path}/config/unicorn/#{unicorn_env}.rb"
+ if remote_file_exists?(config_path)
+ run "cd #{current_path} && BUNDLE_GEMFILE=#{current_path}/Gemfile bundle exec #{unicorn_bin} -c #{config_path} -E #{app_env} -D"
+ else
+ logger.important("Config file for \"#{unicorn_env}\" environment was not found at \"#{config_path}\"", "Unicorn")
+ end
+ end
+ end
+ end
+
+ after "deploy:restart", "unicorn:reload"
+
+ desc "Setup unicorn"
+ task :setup, :roles => :app, :except => {:no_release => true} do
+ run "mkdir -p \"#{shared_path}/config/unicorn\""
+ config_path = "#{shared_path}/config/unicorn/#{rails_env}.rb"
+ template_path = File.expand_path('../../templates/unicorn/unicorn.rb.erb', __FILE__)
+ vars = {
+ 'application' => application,
+ 'current_path' => current_path,
+ 'unicorn_pid' => unicorn_pid,
+ 'unicorn_std_log' => unicorn_std_log,
+ 'unicorn_err_log' => unicorn_err_log,
+ 'stage' => stage,
+ 'unicorn_listen_backlog' => unicorn_listen_backlog,
+ 'unicorn_worker_processes' => unicorn_worker_processes,
+ 'sidekiq_redis_count' => sidekiq_redis_count
+ }
+ put(render_erb_template(template_path, vars), config_path)
+ end
+
+ after :"deploy:setup", :"unicorn:setup";
+
+ namespace :deploy do
+ task :start, :roles => :app do
+ unicorn.start
+ end
+
+ task :stop, :roles => :app do
+ unicorn.stop
+ end
+ end
+ end
end
end
+end
+
+if Capistrano::Configuration.instance
+ Unicorn::CapistranoIntegration.load_into(Capistrano::Configuration.instance)
end