Skip to content

marcosgz/capistrano-multimarket

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

capistrano-multimarket

NOTE

Forked from capistrano-multiconfig. But this extension loads both .yml and .rb files. Use the main project if you want to load only rb files ;-)

Description

Capistrano extension that allows to use multiple configurations(Ruby and YAML files).

MultiMarket extension is similar to multistage extenstion. But it's not only about 'stage' configurations. It's about any configuration that you may need. Extension recursively builds configuration list from configuration root directory. Each configuration loads recursively configuration from it namespace files and own configuration file.

Usage

Install gem

$ gem install capistrano-multimarket

Add to Capfile

set :market_root, 'path/to/your/markets'
require 'capistrano/multimarket'

Example

Assume we have the following configurations:

$ tree config/
config/
└── deploy
    └── markets
        ├── production
        │   ├── blog
        │   │   ├── site1.rb
        │   │   └── site2.yml
        │   └── blog.rb
        ├── production.rb
        └── staging
            └── blog
                ├── site1.rb
                └── site1.yml

Check tasks:

$ cap -f check.rb -T
cap invoke                # Invoke a single command on the remote servers.
cap production:blog:site1 # Load production:blog:site1 configuration
cap production:blog:site2 # Load production:blog:site2 configuration
cap shell                 # Begin an interactive Capistrano session.
cap staging:blog:site1    # Load staging:blog:site1 configuration

Let's try to run task without specified configuration:

$ cap -f check.rb shell
    triggering start callbacks for `shell'
  * executing `multimarket:ensure'
No configuration specified. Please specify one of:
  * production:blog:site1
  * staging:blog:site1
  * production:blog:site2
(e.g. `cap production:blog:site1 shell')

So we must provide configuration as first task:

$ cap -f check.rb staging:blog:site1 shell
  * executing `staging:blog:site1'
    triggering start callbacks for `shell'
  * executing `multimarket:ensure'
  * executing `shell'

Example of YAML config:

$ cat examples/config/deploy/markets/staging/blog/site1.yml
variables:
  application: 'market1'
  app_servers:
    - web1.example.com
    - web2.example.com
roles:
  app:
    - "app1.example.com"
    - "app2.example.com"
  db:
    - "app1.example.com"
    - {primary: true}
string: |
  set :branch, :master
  role(:web) { fetch(:app_servers) }

About

Capistrano multimarket

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages