A Chef cookbook to deploy Ruby applications.
To deploy a Rails application from git:
application '/srv/myapp' do
  git 'https://github.com/example/myapp.git'
  bundle_install do
    deployment true
    without %w{development test}
  end
  rails do
    database 'sqlite3:///db.sqlite3'
    secret_token 'd78fe08df56c9'
    migrate true
  end
  unicorn do
    port 8000
  end
endChef 12.1 or newer is required.
The application_bundle_install resource installs gems using Bundler for a
deployment.
application '/srv/myapp' do
  bundle_install do
    deployment true
    without %w{development test}
  end
endAll actions and properties are the same as the bundle_install resource.
The application_puma resource creates a service for puma.
application '/srv/myapp' do
  puma do
    port 8000
  end
end- :enable– Create, enable and start the service. (default)
- :disable– Stop, disable, and destroy the service.
- :start– Start the service.
- :stop– Stop the service.
- :restart– Stop and then start the service.
- :reload– Send the configured reload signal to the service.
- path– Base path for the application. (name attribute)
- port– Port to listen on. (default: 80)
- service_name– Name of the service to create. (default: auto-detect)
- user– User to run the service as. (default: application owner)
The application_rackup resource creates a service for rackup.
application '/srv/myapp' do
  rackup do
    port 8000
  end
end- :enable– Create, enable and start the service. (default)
- :disable– Stop, disable, and destroy the service.
- :start– Start the service.
- :stop– Stop the service.
- :restart– Stop and then start the service.
- :reload– Send the configured reload signal to the service.
- path– Base path for the application. (name attribute)
- port– Port to listen on. (default: 80)
- service_name– Name of the service to create. (default: auto-detect)
The application_rails resource
application '/srv/myapp' do
  rails do
    database 'sqlite3:///db.sqlite3'
    secret_token 'd78fe08df56c9'
    migrate true
  end
end- :deploy– Create config files and run required deployments steps. (default)
- path– Base path for the application. (name attribute)
- app_module– Top-level application module. Only needed for the :initializer style of secret token configuration. (default: auto-detect)
- database– Database settings for Rails. See the database section below for more information. (option collector)
- migrate– Run database migrations. (default: false)
- precompile_assets– Run- rake assets:precompile. *(default: auto-detect)()
- rails_env– Rails environment name. (default: node.chef_environment)
- secret_token– Secret token for Rails session verification et al.
- secrets_mode– Secrets configuration mode. Set to- :yamlto generate a Rails 4.2 secrets.yml. Set to- :initializerto update- config/initializers/secret_token.rb. (default: auto-detect)
NOTE: At this time secrets_mode :initializer is not implemented.
The database parameters can be set in three ways: URL, hash, and block.
If you have a single URL for the parameters, you can pass it directly to
database:
rails do
  database 'mysql2://myuser@dbhost/myapp'
endPassing a single URL will also set the $DATABASE_URL environment variable
automatically for compatibility with Heroku-based applications.
As with other option collector resources, you can pass individual settings as either a hash or block:
rails do
  database do
    adapter 'mysql2'
    username 'myuser'
    host 'dbhost'
    database 'myapp'
  end
end
rails do
  database({
    adapter: 'mysql2',
    username: 'myuser',
    host: 'dbhost',
    database: 'myapp',
  })
endThe application_ruby resource installs a Ruby runtime for the deployment.
application '/srv/myapp' do
  ruby '2.2'
endAll actions and properties are the same as the ruby_runtime resource.
The application_ruby_gem resource installs Ruby gems for the deployment.
application '/srv/myapp' do
  ruby_gem 'rake'
endAll actions and properties are the same as the ruby_gem resource.
The application_ruby_execute resource runs Ruby commands for the deployment.
application '/srv/myapp' do
  ruby_execute 'rake'
endAll actions and properties are the same as the ruby_execute resource,
except that the cwd, environment, group, and user properties default to
the application-level data if not specified.
The application_thin resource creates a service for thin.
application '/srv/myapp' do
  thin do
    port 8000
  end
end- :enable– Create, enable and start the service. (default)
- :disable– Stop, disable, and destroy the service.
- :start– Start the service.
- :stop– Stop the service.
- :restart– Stop and then start the service.
- :reload– Send the configured reload signal to the service.
- path– Base path for the application. (name attribute)
- config_path– Path to a Thin configuration file.
- port– Port to listen on. (default: 80)
- service_name– Name of the service to create. (default: auto-detect)
- user– User to run the service as. (default: application owner)
The application_unicorn resource creates a service for unicorn.
application '/srv/myapp' do
  unicorn do
    port 8000
  end
end- :enable– Create, enable and start the service. (default)
- :disable– Stop, disable, and destroy the service.
- :start– Start the service.
- :stop– Stop the service.
- :restart– Stop and then start the service.
- :reload– Send the configured reload signal to the service.
- path– Base path for the application. (name attribute)
- port– Port to listen on. (default: 80)
- service_name– Name of the service to create. (default: auto-detect)
- user– User to run the service as. (default: application owner)
Development sponsored by Chef Software, Symonds & Son, and Orion.
The Poise test server infrastructure is sponsored by Rackspace.
Copyright 2015-2017, Noah Kantrowitz
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.