Adoptable Cookbooks List

Looking for a cookbook to adopt? You can now see a list of cookbooks available for adoption!
List of Adoptable Cookbooks

Supermarket Belongs to the Community

Supermarket belongs to the community. While Chef has the responsibility to keep it running and be stewards of its functionality, what it does and how it works is driven by the community. The chef/supermarket repository will continue to be where development of the Supermarket application takes place. Come be part of shaping the direction of Supermarket by opening issues and pull requests or by joining us on the Chef Mailing List.

Select Badges

Select Supported Platforms

Select Status

The stackstorm cookbook has been deprecated

Author provided reason for deprecation:

The stackstorm cookbook has been deprecated and is no longer being maintained by its authors. Use of the stackstorm cookbook is no longer recommended.

RSS

stackstorm (12) Versions 0.3.0

Installs/Configures stackstorm

Policyfile
Berkshelf
Knife
cookbook 'stackstorm', '= 0.3.0', :supermarket
cookbook 'stackstorm', '= 0.3.0'
knife supermarket install stackstorm
knife supermarket download stackstorm
README
Dependencies
Changelog
Quality 100%

StackStorm chef cookbook

Build Status

Cookbook for StackStorm Automation as a Service. This cookbook is used to install and bring up St2 components using Chef.

Compatibility

Use version <0.2.5 of this cookbook with chef <12.4.0.

Starting with version *0.3.0, Packagecloud repo will be used to install Stackstorm packages instead of building from source.

Supported Platforms

Tested to work on ubuntu 14.04, fedora 20 and centos 7.0.

Attributes

NOTE: By default, latest stable version of st2 and st2mistral will be installed. Overwrite this behavior using custom wrapper cookbook.

Common attributes

Key Type Description Default
['stackstorm']['install_stackstorm']['build'] String Build number of stackstorm packages. 'current'
['stackstorm']['install_repo']['suite'] String Suite selects package repository, use stable or unstable. 'stable'
['stackstorm']['install_repo']['debug_package'] Boolean Set to true to install st2debug package. false
['stackstorm']['home'] String Base directory where is St2 is installed (same path as in the os-packages). '/opt/stackstorm'
['stackstorm']['bin_dir'] String Directory where St2 binaries are located. It can be overrided by the install recipe. '/usr/bin'
['stackstorm']['etc_dir'] String Configuration directory of St2. '/etc/st2'
['stackstorm']['conf_path'] String St2 configuration file path. '/etc/st2/st2.conf'
['stackstorm']['log_dir'] String Log directory path where St2 services write log files. '/var/log/st2'
['stackstorm']['run_user'] String User used to run St2 services (except action runners). 'st2'
['stackstorm']['run_group'] String Group used to run St2 services (except action runners). 'st2'
['stackstorm']['action_runners'] Integer Number of action runners to be spawned. (TODO) 10
['stackstorm']['roles'] Array List of roles to bring up on a node. Set a combination of the following roles: controller, worker and client. []
['stackstorm'][config'] Hash Various configuration options used to build up the configuration file. see attributes file

User management

Key Type Description Default
['stackstorm']['user']['user'] String System user used by stackstorm stack. 'stanley'
['stackstorm']['user']['group'] String System group used by stackstorm stack. 'stanley'
['stackstorm']['user']['home'] String Path to stanley's home directory. '/home/stanley'
['stackstorm']['user']['authorized_keys'] Array List of ssh public keys added to stanley's* ~/.ssh/authorized_keys* file. []
['stackstorm']['user']['ssh_key'] String Stanley's ssh private key. nil
['stackstorm']['user']['ssh_pub'] String Stanley's ssh public key. nil
['stackstorm']['user']['ssh_key_bits'] Integer Specifies the number of bits for ssh key creation. 2048
['stackstorm']['user']['enable_sudo'] Boolean Enables sudo privileges for stanley. true

StackStorm uses system_user option to specify privileges used to execute local or remote actions. This user is managed and configured by this cookbook. Stanley user is different from run_user whose privileges used for running all St2 services (except action runners). Action runners are started with root privileges and StackStorm drops them to stanley's privileges during action execution. If root privileges for running actions are required stanley must be valid sudoer.

Stanley's ssh key is automatically generated if no ssh_key is provided. This is the default behavior.

stackstorm.config attributes

There are different attributes providing options values which are substituted into st2.conf file. For more details have look at the [config.rb](attributes/config.rb).

Usage

StackStorm nodes can have several roles these are controller and worker. Controller nodes run API service, sensor container and others. While workers execute actions on nodes so they run only action runner and mistral executor services.

Usage of mistral is provided by the mistral cookbook, details are here

To chose specific roles for a node define ['stackstorm']['roles'] attribute to contain one of the following roles: controller, worker, client, or their combination combination. For example with a json attribute file.

{
  "run_list": [ "recipe[stackstorm::default]" ],
  "attributes": {
    "stackstorm": {
      "roles": [ "worker", "client" ],
      "config": { "lots of": "configuration" }
    }
  }
}

Invocation

Define roles with the stackstorm.roles attribute, provide valid configuration options and include "recipe[stackstorm::default]" into your run list. The default recipe downloads and installs StackStorm packages required for given roles, writes configuration files and filnally brings up StackStorm system services.

Mind that the valid configuration must be provided such as RabbitMQ and MongoDB endpoints. Otherwise StackStorm services fail when trying to establish connections.

stackstorm::bundle

For those who wants to play with StackStorm there's an all-in-one solution which installs and configures StackStorm system services as well as all required components such as RabbitMQ, MongoDB and Mistral . To install pre-configured StackStorm bundle just include the "recipe[stackstorm::bundle]" into your run list.

License and Authors

Contributors

0.2.2

  • Native repository layout support
  • Various fixes, tested on Fedora 20, Centos 70 and Ubuntu 14.04

0.1.0

Initial release of stackstorm cookbook

Collaborator Number Metric
            

0.3.0 passed this metric

Foodcritic Metric
            

0.3.0 passed this metric