This module is a reference implementation for the cubbystack OpenStack Module.
This module is able to deploy a multi-node OpenStack environment out of the box. It currently supports two types of nodes:
- Cloud Controller: Runs all services except for
nova-compute
- Compute Node: Runs
nova-compute
In the future, this module will support more types as well as different variations on those types. Each type will probably be broken out into its own branch.
This module has been tested with Ubuntu 12.04. Each node only requires one network interface, although support for three interfaces is included in the configuration.
Puppet 3.2. You must also have the future parser enabled.
Hiera 1.3.
The cubbystack module.
This module installs just like any other Puppet module. Make sure it is located in a correct modulepath
directory such as /etc/puppet/modules
.
This modules includes an example Hiera configuration file and data source. If you'd like to use the examples provided, first copy the Hiera configuration:
$ sudo cp hiera/hiera.yaml /etc/
$ sudo cp hiera/hiera.yaml /etc/puppet/
Then copy the example data source:
$ sudo mkdir /etc/puppet/hieradata
$ sudo cp hiera/common.yaml /etc/puppet/hieradata/
Finally, review the common.yaml
file and change any parameters that need modified to suit your environment.
Once the module is installed and Hiera is configured, the last step is to apply a role to a node. This module comes with two roles: a cloud controller and compute node:
node 'cloud.example.com' {
include havana::roles::controller
}
node /c[0-9]+.example.com/ {
include havana::roles::compute
}
This module is a reference module. Its purpose is to show you can use cubbystack in a practical way. Therefore this module will not cover all different types of OpenStack environments.
This module is based off of Chris Hoges's excellent Puppet work.