Last updated: 2014-09-05
The AT&T Foundry currently runs a number of diverse infrastructure projects in various sections - such as Compute, Storage, and PaaS frameworks - which all have vastly varying demands. To be able meet these demands, it was necessary to develop our own solution for automation, orchestration, hardware abstraction and provisioning.
Our ultimate goal was to build a framework with excellent code quality, inline with industry standards and includes the obligatory abstraction layers. It was essential to make sure our development process introduces best practices for how all services included in the framework as we test various compositions as well as evaluate various underlying technologies. The result of this work is a framework called Occam, which is a complete automation, orchestration, and development framework to manage your infrastructure and services you run on top.
Occam has been confirmed to be working with a number of infrastructure applications. These applications are self-contained entities that can be easily installed inside the Occam core. You can for instance, using the OpenStack Havana Cloud Application and Occam, deploy many separated Havana clouds - so called zones - with completely different configurations.
Occam is built using Puppet and using the proven development workflow consisting of Gitflow, continuous integration and Test-Driven Development (puppet-lint, spec). We wanted to make sure that the various zones have been brought up with integrity why Tempest was also introduced. To properly monitor and test performance irrespectively of configuration of the zone we also introduced benchmark tests.
The Puppet orchestration layer is following the well-known role/profile paradigm, which allows us to abstract all local changes and keep the original modules unmodified and intact. This does not only let us take advantage of the efforts within the larger community, but also easily & promptly upgrade all components. It also allows us to introduce new and old components as we evaluate them.
The target deployment zone can easily be configured using Hiera configuration files, which optionally can be encrypted using GPG to allow for better security on deployed versions of the zone, yet allow development to be more seamless.
We have also included a Vagrant configuration to allow for seamless local development.
Occam consists of many components, from which most prominent are:
- Puppet + hiera + mcollective for automation and orchestration
- Occamengine for bare metal provisioning and external node classification (ENC)
- Logstash + Elasticsearch + Kibana for log collection and analysis
- Zabbix for monitoring
You can generate exhaustive documentation by running the following commands:
Install rvm if you do not have it:
% curl -sSL https://get.rvm.io | bash
Install the right ruby version:
% rvm install ruby-1.8.7
Install the necessary gems
% bundle install
Install dependencies for compiling documentation. You can do this globally, but I strongly suggest using a virtualenvwrapper. It's a great way to keep your python modules isolated and version pegged. I also recommend pip as it allows you to uninstall packages, install from requirements files, etc.
Installing virtualenvwrapper:
% sudo easy_install virtualenvwrapper && pip install virtualenvwrapper
You'll also need to add something like the following to your shell environment.
export WORKON_HOME=$HOME/.virtualenvs export PROJECT_HOME=$HOME/Devel source /usr/local/bin/virtualenvwrapper.sh
Create a virtualenv for occam and install doc dependencies.
% mkvirtualenv occam % pip install -r doc-requirements.txt
Generate the latest documentation
% rake doc:build
This will generate two HTML files under the docs directory: readme.html and quickstart.html. Please refer to the sections below for details on what you will find in these two files.
The docs/build/htmls/README.html file contains an exhaustive documentation of Occam.
% open docs/build/html/README.html
Note: If you would like to just try it out locally using Vagrant, you will within this file instructions for how to do so.
The docs/build/htmls/quickstart.html file contains a quickstart tutorial for how to get an Havana cloud up and running on bare metal nodes using Occam.
% open docs/build/htmls/quickstart.html
Any questions or want to start contributing, you can contact any of the Authors & Contributors. We also have an #occam channel on Freenode's IRC.
- James A. Kyle <[email protected]>
- Jerry A. Higgs <[email protected]>
- Ari Saha <[email protected]>
- Paul McGoldrick <[email protected]>
- Erik Sundelof <[email protected]>
- Ashu Sharma <[email protected]>
- Tomasz Z. Napierała <[email protected]>
- Piotr Misiak <[email protected]>
- Kamil Świątkowski <[email protected]>
- Damian Szeluga <[email protected]>
- Michał Skalski <[email protected]>