Skip to content
cstackpole edited this page Nov 29, 2013 · 11 revisions

Puppet

Puppet is a configuration management tool that is extreamly useful. It ensures that the admin just needs to manage a single resource instead of all the nodes in the cluster. It ensures that software is consistantly installed, configured, and properly started on all systems.

Installation

The puppet version in almost every repo is way to outdated. Puppet 2.7 or better is /higly/ recommended by this guide. Thankfully Puppet Labs provides a really good resource.

Check the Puppet Labs yum repo for the latest version. Look for the 'puppetlabs-release' rpm for the highest release.

$ sudo yum install https://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm

Once that is installed, we can now install puppet.

$ sudo yum install puppet-server

Configure the master to autosign the SSL certs for nodes so we don't have to do them by hand for each node. This should be disabled later as it could be a security risk.

$ sudo vim /etc/puppet/autosign.conf
*.cluster.domain

Turn Puppetmaster on during boot

$ sudo chkconfig puppetmaster on

Start the puppetmaster

$ sudo service puppetmaster start

Verify that the puppet client can connect to the server. This won't do much but it should setup the keys and get the basic files configured.

$ sudo puppet agent -t

If that doesn't work or it times out, try to add the puppet hostname to /etc/hosts. Then try again.

$ sudo sh -c 'echo "127.0.0.1 puppet.cluster.domain" >> /etc/hosts'

If you get an error about "getaddrinfo: Name or service not known" we will fix this permanently when we get to the DNSMasq section but for now run:

$ sudo puppet agent -t --server=frontend01.cluster.domain

Once the puppet client and server can talk, there will most likely be an "error" about "Could not find node definition". Lets fix that.

$ sudo vim /etc/puppet/manifests/site.pp
node 'frontend01.cluster.domain' { }

Firewall

Puppet Labs provides a forge for community modules. The firewall module is very useful.

Install it:

$ puppet module install puppetlabs-firewall

Configure the frontend node configuration:

$ sudo vim /etc/puppet/manifests/site.pp
node 'frontend01.cluster.domain' {
__# Include the rules that are common to all cluster nodes
__include cluster_firewall
__# Open the port for the puppet master server.
__firewall { '8140 open puppet master':
______port => '8140',
______proto => 'tcp',
______action => 'accept',
__}
}

Configure the cluster_firewall:

$ sudo mkdir -p /etc/puppet/modules/cluster_firewall/manifests

There are three parts to the cluster firewall; the pre.pp is for the rules that we need to run first, the post.pp is for the rules that we want to run last, and init.pp is for the main rule set.

$ sudo vim /etc/puppet/modules/cluster_firewall/manifests/init.pp
__class cluster_firewall () {
____resources { "firewall": purge => true }
____Firewall {
______before => Class['cluster_firewall::post'],
______require => Class['cluster_firewall::pre'],
____}
____# Open SSH on all the nodes.
____firewall { '22 open ssh':
______port => '22',
______proto => 'tcp',
______action => 'accept',
____}
____include cluster_firewall::pre
____include cluster_firewall::post
}

$ sudo vim /etc/puppet/modules/cluster_firewall/manifests/pre.pp
class cluster_firewall::pre {
__Firewall { require => undef, }
__firewall { '000 accept all icmp':
____proto => 'icmp',
____action => 'accept',
__}->
__firewall { '001 accept all to lo interface':
____proto => 'all',
____iniface => 'lo',
____action => 'accept',
__}->
__firewall { '002 accept related established rules':
____proto => 'all',
____state => ['ESTABLISHED' , 'RELATED'],
____action => 'accept',
__}
}

$ sudo vim /etc/puppet/modules/cluster_firewall/manifests/post.pp
class cluster_firewall::post {
__firewall { '999 drop all':
____proto => 'all',
____action => 'drop',
____before => undef,
__}
}

Test the config and ensure it all works.

sudo puppet agent -t

If you have a problem, try running 'puppet parser validate' on the files. For example:

$ puppet parser validate /etc/puppet/manifests/site.pp

It won't catch everything, but it should catch typos.

Configure the puppet client

Turn Puppet client on during boot

$ sudo chkconfig puppet on

Start the puppet client

$ sudo service puppet start

Clone this wiki locally