- Description
- Setup - The basics of getting started with
puppet
- Usage - Configuration options and additional functionality
- Limitations - OS compatibility, etc.
- Development - Guide for contributing to the module
This Puppet module is primarily designed to manage the Puppet server itself, automating its configuration, deployment, and maintenance tasks. This ensures the Puppet server operates efficiently and remains up-to-date.
Additionally, the module includes functionality to manage the Puppet agent as well.
This module can be utilized in two primary ways:
-
As a Regular Puppet Module (e.g., included in a Puppetfile)
For direct inclusion in your Puppet environment, specify the module in your Puppetfile as follows:
mod 'puppet', git: 'https://github.com/aursu/puppet-puppet.git', tag: 'v0.19.1'
Alternatively, you can specify the version directly if it’s available from the module repository on Puppet Forge:
mod 'aursu/puppet', '0.19.1'
-
As a Puppet Server Bootstrap Tool Using Puppet Bolt
The module includes a Bolt project located in the
bootstrap/bolt
subfolder. Within this project, there is a Bolt plan namedpuppet_bootstrap::server
that is specifically designed for bootstrapping a Puppet server.Using this setup with Puppet Bolt facilitates a more efficient and straightforward installation process for the Puppet server. This method provides a predefined sequence of actions that automate much of the manual setup, streamlining the deployment of Puppet server environments. It also significantly reduces the complexity of the initial server configuration.
Initiate the bootstrapping and subsequent Puppet agent run in the production environment with the following commands:
bolt plan run puppet_bootstrap::server -t puppetservers bolt plan run puppet_agent::run -t puppetservers environment=production
For a more detailed description, refer to the
bootstrap
directory.
When integrated into a Puppet catalog to configure a Puppet server, the puppet
module offers comprehensive control over several crucial configurations and components of both the Puppet server and the overall Puppet infrastructure:
To configure a custom cache directory for r10k
instead of the default (/var/cache/r10k
, as defined in puppet::params
), there are a few options:
-
Define the
r10k_cachedir
parameter:- If the
puppet::profile::server
profile is in use, you can set ther10k_cachedir
parameter to the desired cache directory. - Similarly, if the
puppet::profile::puppet
profile is in use, you can also define this parameter for that profile.
- If the
-
Set the global variable
puppet::globals::r10k_cachedir
:- Alternatively, define the global variable
puppet::globals::r10k_cachedir
. This corresponds to ther10k_cachedir
parameter in thepuppet::globals
class, allowing you to override the default cache directory across the entire configuration. This option is particularly useful when Bolt plans, such aspuppet_bootstrap::server
orpuppet::server::bootstrap
, are in use.
- Alternatively, define the global variable
To schedule the r10k
command in cron
, use the puppet::r10k_crontab_setup
flag. Set this flag to true
to enable the setup of r10k
in the crontab.
The puppet::agent::bootstrap
class is responsible for bootstrapping a Puppet node. It performs the following steps:
-
First Run: It executes the
puppet agent --test
command to initiate the creation of a Puppet private key and request a certificate from the Puppet server. -
Subsequent Runs: On subsequent executions, it attempts to download the certificate from the Puppet server. If the certificate is not yet available, the agent will continue to attempt fetching it on each run until the certificate is successfully retrieved.
-
Handling
certname
: If acertname
is specified during the certificate request, the private key and certificate will be propagated into the appropriate locations using thefqdn
(fully qualified domain name), if it differs fromcertname
.
The Bolt plan puppet::bootstrap
is available to automate the setup of Puppet agents on nodes. This plan performs the following tasks:
-
Install Puppet Agent: It uses the
puppet::agent::install
Bolt plan to install the Puppet agent on the target node. -
Configure Puppet: It configures the
puppet.conf
file with the necessary settings, including the Puppet server name and, if provided, thecertname
. -
Run Bootstrap: Finally, it runs the
puppet::agent::bootstrap
Bolt plan to initiate the Puppet agent bootstrap process, which handles certificate requests and private key creation.