Skip to content

Latest commit

 

History

History
62 lines (47 loc) · 2.78 KB

README.md

File metadata and controls

62 lines (47 loc) · 2.78 KB

lab-in-a-box

A minimalist multi-machine puppet lab in vagrant. Meant to be a starting point for your own labs. The puppetmaster is currently Centos6.5 as this is the lowest common denominator in most modern puppet set ups (ruby 1.8.7 - yada yada).

Certs are distributed with this, you should know if you care about that.

##Instructions

  • Download and install Vagrant - http://www.vagrantup.com/downloads.html
  • Download and install VirtualBox - https://www.virtualbox.org/wiki/Downloads
  • On windows
    • Be sure you have and use powershell
    • For vagrant ssh easiest thing is to install Github for Windows - https://windows.github.com/
    • Add vagrant bin directory to your path - likely C:\Program Files\HashiCorp\Vagrant\bin
    • Add git bin path to your path or launch git shell
  • Download or clone this repo
  • Navigate to where you downloaded or cloned this repo
  • Open the Vagrantfile and:
    • set up any shared folders (for individual testing of modules).
    • uncomment the appropriate boxes you wish to work with.
  • vagrant up or vagrant up --provider=virtualbox

##Currently provides

  • An isolated private network (TEST-NET-3 documentation address space)
  • DNS not reliant on vagrant plugins
  • A Puppet Master running via mod_passenger
  • Ubuntu 12.04 and 14.04 LTS machines
  • Centos 6.5 and Centos 7.0 machines
  • A Scientific Linux 6.5 machine

No plugins are required for any of this to work so it should be truly cross-platform. Downside is you need 2 boxes and a 1GB Disk / 1GB RAM footprint(and this is cutting it pretty tight).

Will fold in Fedora Core and Debian Wheezy at some point. OpenSUSE if someone asks.

##Validating puppet vagrant ssh ${machine} -c "sudo puppet agent -t"

##More Info

DNS is managed with bind via puppet/modules/simple_dns/files/db.example.com and reverse dns is managed via puppet/modules/simple_dns/files/db.203.0.113. Normal DNS caveats apply:

  • Increment the serial
  • Keep reverse and forward in sync
  • Keep it copacetic with the Vagrantfile
  • If it's not working increment the serial.

By default the puppetmaster forwards DNS requests through the host over the nat connection.

For lots of detail on setting up a complete sandbox see:

Vagrant docs are also always helpful, especially for modifying vbox params like memory.

And you can always yell at PUG members.

For the packer templates used for the machines see: https://github.com/boston-pug/packer-templates

Boxes are hosted at Northeastern (www.ccs.neu.edu). Beat Nick Cammorato(@cammoraton) about the head and shoulders if you have issues downloading them on anything but Windows.