Capistrano Unicorn
Capistrano plugin that integrates Unicorn tasks into capistrano deployment script.
Installation
Install library from rubygems:
gem install capistrano-unicorn
Usage
Setup
Add the library to your Gemfile:
group :development do
gem 'capistrano-unicorn', :require => false
endAnd load it into your deployment script config/deploy.rb:
require 'capistrano-unicorn'Add unicorn restart task hook:
after 'deploy:restart', 'unicorn:restart' # app IS NOT preloaded
after 'deploy:restart', 'unicorn:reload' # app preloadedCreate a new configuration file config/unicorn/unicorn.rb or config/unicorn/STAGE.rb, where stage is your deployment environment.
Example config - examples/rails3.rb. Please refer to unicorn documentation for more examples and configuration options.
Test
First, make sure you're running the latest release:
cap deploy
Then you can test each individual task:
cap unicorn:start
cap unicorn:stop
cap unicorn:reload
Configuration
You can modify any of the following options in your deploy.rb config.
-
unicorn_env- Set unicorn environment. Default torails_envvariable. -
unicorn_pid- Set unicorn PID file path. Default tocurrent_path/tmp/pids/unicorn.pid -
unicorn_bin- Set unicorn executable file. Default tounicorn. -
unicorn_bundle- Set bundler command for unicorn. Default tobundle.
Available Tasks
To get a list of all capistrano tasks, run cap -T:
cap unicorn:add_worker # Add a new worker
cap unicorn:remove_worker # Remove amount of workers
cap unicorn:reload # Reload Unicorn
cap unicorn:restart # Restart Unicorn
cap unicorn:shutdown # Immediately shutdown Unicorn
cap unicorn:start # Start Unicorn master process
cap unicorn:stop # Stop Unicorn
License
See LICENSE file for details.