/puppet-debugging-kit

A batteries-included environment for debugging Puppet powered infrastructure.

Primary LanguageRuby

Puppet Debugging Kit

The only good bug is a dead bug.

This project provides a batteries-included Vagrant environment for debugging Puppet powered infrastructures.

Table of Contents

Setup

Getting the debugging kit ready for use consists of three steps:

  1. Ensure the proper Vagrant plugins are installed.

  2. Create VM definitions in config/vms.yaml.

  3. Clone Puppet Open Source projects to src/puppetlabs (optional).

  4. Install Bolt to enable bolt provisioning (optional).

Rake tasks and templates are provided to help with all three steps.

Install Vagrant Plugins

Two methods are available depending on whether a global Vagrant installation, such as provided by the official packages from vagrantup.com, is in use:

Create VM Definitions

Debugging Kit virtual machine definitions are stored in the file config/vms.yaml and an example is provided as config/vms.yaml.example. The example can simply be copied to config/vms.yaml, but it contains a large number of VM definitions which adds some notable lag to Vagrant start-up times. Start-up lag can be remedied by pruning unwanted definitions after copying the example file.

Clone Puppet Open Source Projects

The poss-envpuppet role is designed to run Puppet in guest machines directly from Git clones located on the host machine at src/puppetlabs/. This role is useful for inspecting and debugging changes in behavior between versions without re-installing packages.

The required Git clones can be created by running the following Rake task:

rake setup:poss

Usage

Use of the debugging kit consists of:

  • Creating a new VM definition in config/vms.yaml.

    • The box: component determines which Vagrant basebox will be used.
  • Assigning a list of "roles" that customize the VM behavior.

    • The role list can be viewed as a stack―the last entry is applied first.
    • Most VMs start with the base role which auto-assigns an IP address and sets up network connectivity.
    • The default roles can be found in data/puppet_debugging_kit/roles.yaml, and are explained in more detail below.
  • Optionally using "bolt based provisioning"

    • Building roles to call Bolt modules.
    • Roles can contain triggers or provisioners to initiate plans, tasks, or commands.
    • An example set are found in config/bolt_vms.yaml.example.
    • An example Puppetfile is found in Puppetfile.example.

Roles

General-Purpose Roles

PE-Specific Roles

Several roles are available to assist with creating PE machines:

POSS-Specific Roles

There are a few roles that assist with creating VMs that run Puppet Open Source Software (POSS).

There are also roles for legacy POSS software:

Bolt Based Provisioning

Bolt modules can now be used to do the provisoning and configuration of the machines. An example set of plans have been provided in the Puppetfile.example which will enable provisioning a PE infrastructure. To use the bolt plans from the Puppetfile the following steps can be followed.

  1. Install Bolt as needed.
  2. Copy the Puppetfile.example to Puppetfile and add any additional modules.
  3. Install the modules with vagrant bolt puppetfile install.
  4. Copy the config/bolt_vms.yaml.example to config/bolt_vms.yaml.
  5. Update any parameters in the roles of the config/bolt_vms.yaml to specify PE versions or download locations.

The example VMs in the config/bolt_vms.yaml use custom roles at the bottom of the file. There are roles to deploy a PE master, agent, and compiler. See the deploy_pe module for more parameter information.

  • pe_master Installs the PE master on the VM using the specified parameters.
  • pe_compiler Installs a PE compiler from the PE master.
  • pe_agent Installs a PE agent from the PE master.

The roles define provisioners and triggers. More information on how to use the bolt triggers and provisioners can be found in the vagrant-bolt documentation.

This is currently only for *nix vagrant hosts. Windows vagrant host compatibility is in progress in the example plans.

Extending and Contributing

The debugging kit can be thought of as a library of configuration and data for Oscar. Data is loaded from two sets of YAML files:

config
└── *.yaml         # <-- User-specific customizations
data
└── puppet_debugging_kit
    └── *.yaml     # <-- The debugging kit library

Everything under data/puppet_debugging_kit is loaded first. In order to avoid merge conflicts when the library is updated, these files should never be edited unless you plan to submit your changes as a pull request.

The contents of config/*.yaml are loaded next and can be used to extend or override anything provided by data/puppet_debugging_kit. These files are not tracked by Git and are where user-specific customizations should go.