2013-05-24 16:56:35 -07:00
|
|
|
:title: Puppet Master
|
|
|
|
|
|
|
|
.. _puppet-master:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-05-24 16:56:35 -07:00
|
|
|
Puppet Master
|
|
|
|
#############
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2012-07-20 12:38:54 -07:00
|
|
|
Puppet agent is a mechanism use to pull puppet manifests and configuration
|
|
|
|
from a centralized master. This means there is only one place that needs to
|
|
|
|
hold secure information such as passwords, and only one location for the git
|
|
|
|
repo holding the modules.
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-05-24 16:56:35 -07:00
|
|
|
At a Glance
|
|
|
|
===========
|
|
|
|
|
|
|
|
:Hosts:
|
|
|
|
* ci-puppetmaster.openstack.org
|
|
|
|
* http://puppet-dashboard.openstack.org:3000/
|
|
|
|
:Puppet:
|
|
|
|
* :file:`modules/openstack_project/manifests/puppetmaster.pp`
|
|
|
|
:Projects:
|
|
|
|
* https://puppetlabs.com/
|
|
|
|
:Bugs:
|
|
|
|
* http://bugs.launchpad.net/openstack-ci
|
|
|
|
* http://projects.puppetlabs.com/
|
|
|
|
:Resources:
|
|
|
|
* `Puppet Language Reference <http://docs.puppetlabs.com/references/2.7.latest/type.html>`_
|
|
|
|
|
2012-05-15 17:21:49 -04:00
|
|
|
Puppet Master
|
|
|
|
-------------
|
|
|
|
|
|
|
|
The puppet master is setup using a combination of Apache and mod passenger to
|
2013-01-18 12:26:05 -08:00
|
|
|
ship the data to the clients.
|
|
|
|
|
|
|
|
The cron jobs, current configuration files and more can be done with ``puppet
|
|
|
|
apply`` but first some bootstrapping needs to be done.
|
|
|
|
|
|
|
|
First want to install these from puppetlabs' apt repo, but we typically pin to
|
|
|
|
a specific version, so you'll want to copy in the preferences file from the git
|
|
|
|
repository. Configuration files for puppet master are stored in a git repo
|
|
|
|
clone at ``/opt/config/production`` so we'll just do this checkout now and copy
|
|
|
|
over the preferences file:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2013-01-18 12:26:05 -08:00
|
|
|
git clone git://github.com/openstack-infra/config.git /opt/config/production
|
|
|
|
cp /opt/config/production/modules/openstack_project/files/00-puppet.pref /etc/apt/preferences.d/
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-01-18 22:52:46 -08:00
|
|
|
Then we can add the repo and install the packages, we'll also install the hiera
|
|
|
|
packages here which are used to maintain secret information on the
|
|
|
|
puppetmaster:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
.. code-block:: bash
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-01-18 22:52:46 -08:00
|
|
|
apt-add-repository "deb http://apt.puppetlabs.com `lsb_release -cs` devel"
|
|
|
|
apt-key adv --keyserver pool.sks-keyservers.net --recv <KEY_ID>
|
2013-01-18 12:26:05 -08:00
|
|
|
apt-get update
|
2013-01-18 22:52:46 -08:00
|
|
|
apt-get install puppet puppetmaster-passenger hiera hiera-puppet
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-01-18 12:26:05 -08:00
|
|
|
Finally, install the modules and use ``puppet apply`` to finish configuration:
|
2012-06-06 20:54:34 +01:00
|
|
|
|
2013-01-18 12:26:05 -08:00
|
|
|
.. code-block:: bash
|
2012-06-06 20:54:34 +01:00
|
|
|
|
2013-01-18 12:26:05 -08:00
|
|
|
bash /opt/config/production/install_modules.sh
|
|
|
|
puppet apply --modulepath='/opt/config/production/modules:/etc/puppet/modules' -e 'include openstack_project::puppetmaster'
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2013-01-18 22:52:46 -08:00
|
|
|
Note: Hiera uses a systemwide configuration file in ``/etc/puppet/hiera.yaml``
|
|
|
|
and this setup supports multiple configurations. The two sets of environments
|
2012-12-02 11:52:32 -08:00
|
|
|
that OpenStack Infrastructure uses are ``production`` and ``development``.
|
2013-01-18 22:52:46 -08:00
|
|
|
``production`` is the default is and the environment used when nothing else is
|
|
|
|
specified. Then the configuration needs to be placed into common.yaml in
|
2012-07-20 12:38:54 -07:00
|
|
|
``/etc/puppet/hieradata/production`` and ``/etc/puppet/hieradata/development``.
|
|
|
|
The values are simple key-value pairs in yaml format.
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
Adding a node
|
|
|
|
-------------
|
|
|
|
|
2012-07-20 12:38:54 -07:00
|
|
|
On the new server connecting (for example, review.openstack.org) to the puppet master:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
sudo apt-get install puppet
|
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
Then edit the ``/etc/default/puppet`` file to change the start variable:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
.. code-block:: ini
|
|
|
|
|
|
|
|
# Start puppet on boot?
|
|
|
|
START=yes
|
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
The node then needs to be configured to set a fixed hostname and the hostname
|
|
|
|
of the puppet master with the following additions to ``/etc/puppet/puppet.conf``:
|
|
|
|
|
|
|
|
.. code-block:: ini
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
[main]
|
2012-07-20 12:38:54 -07:00
|
|
|
server=ci-puppetmaster.openstack.org
|
|
|
|
certname=review.openstack.org
|
2012-06-06 20:54:34 +01:00
|
|
|
|
|
|
|
The cert signing process needs to be started with:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
sudo puppet agent --test
|
2012-05-15 17:21:49 -04:00
|
|
|
|
2012-06-06 20:54:34 +01:00
|
|
|
This will make a request to the puppet master to have its SSL cert signed.
|
|
|
|
On the puppet master:
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
sudo puppet cert list
|
|
|
|
|
|
|
|
You should get a list of entries similar to the one below::
|
|
|
|
|
2012-07-20 12:38:54 -07:00
|
|
|
review.openstack.org (44:18:BB:DF:08:50:62:70:17:07:82:1F:D5:70:0E:BF)
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
If you see the new node there you can sign its cert on the puppet master with:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
2012-07-20 12:38:54 -07:00
|
|
|
sudo puppet cert sign review.openstack.org
|
2012-06-06 20:54:34 +01:00
|
|
|
|
|
|
|
Finally on the puppet agent you need to start the agent daemon:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
sudo service puppet start
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
Now that it is signed the puppet agent will execute any instructions for its
|
|
|
|
node on the next run (default is every 30 minutes). You can trigger this
|
2012-06-06 20:54:34 +01:00
|
|
|
earlier by restarting the puppet service on the agent node.
|
2012-05-15 17:21:49 -04:00
|
|
|
|
|
|
|
Important Notes
|
|
|
|
---------------
|
|
|
|
|
|
|
|
#. Make sure the site manifest **does not** include the puppet cron job, this
|
|
|
|
conflicts with puppet master and can cause issues. The initial puppet run
|
|
|
|
that create users should be done using the puppet agent configuration above.
|
2012-06-06 20:54:34 +01:00
|
|
|
|
|
|
|
#. If you do not see the cert in the master's cert list the agent's
|
|
|
|
``/var/log/syslog`` should have an entry showing you why.
|