Skip to content

tkwwarchive/capistrano-pm2

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Capistrano::pm2 Gem Version

nodejs pm2 support for Capistrano 3.x

Installation

Add this line to your application's Gemfile:

gem 'capistrano', '~> 3.1.0'
gem 'capistrano-pm2'

And then execute:

$ bundle

Or install it yourself as:

$ gem install capistrano-pm2

Usage

Require in Capfile to use the default task:

require 'capistrano/pm2'

The task will run before deploy:restart as part of Capistrano's default deploy, or can be run in isolation with cap production pm2:restart. You can also invoke it in your deploy.rb:

namespace :deploy do
  desc 'Restart application'
  task :restart do
    # invoke 'npm:install'
    invoke 'pm2:restart'
  end

  after :publishing, :restart
end

Available Tasks

cap pm2:delete                     # Delete pm2 application
cap pm2:list                       # Show pm2 application info
cap pm2:logs                       # Watch pm2 logs
cap pm2:restart                    # Restart app gracefully
cap pm2:setup                      # Install pm2 via npm on the remote host
cap pm2:start                      # Start pm2 application
cap pm2:status                     # List all pm2 applications
cap pm2:stop                       # Stop pm2 application

Configurable options:

set :pm2_app_name, nil                            # app name for pm2, default cap :application

set :pm2_app_command, 'main.js'                   # default, runs main.js
set :pm2_target_path, -> { release_path.join('subdir') } # default not set

# Or Alternatively, you can replace the prior two options with a PM2 Process File
# See: http://pm2.keymetrics.io/docs/usage/application-declaration/
# Note: You'll still want to have a proper :pm2_app_name set to query logs, get status, etc.
# for the application that you're actually deploying.

set :pm2_process_file, '/var/www/myapp/shared/pm2.config.js'  # Example, defaults to nil

set :pm2_roles, :all                              # default, cap roles to run on
set :pm2_env_variables, {}                        # default, env vars for pm2
set :pm2_start_params, ''                         # default, pm2 start params see http://pm2.keymetrics.io/docs/usage/quick-start/#cheat-sheet

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

About

This is a pm2 handler for capistrano 3.x.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%