- 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/boltsubfolder. Within this project, there is a Bolt plan namedpuppet_bootstrap::serverthat 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=productionFor a more detailed description, refer to the
bootstrapdirectory.
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_cachedirparameter:- If the
puppet::profile::serverprofile is in use, you can set ther10k_cachedirparameter to the desired cache directory. - Similarly, if the
puppet::profile::puppetprofile 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_cachedirparameter in thepuppet::globalsclass, allowing you to override the default cache directory across the entire configuration. This option is particularly useful when Bolt plans, such aspuppet_bootstrap::serverorpuppet::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 --testcommand 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 acertnameis 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::installBolt plan to install the Puppet agent on the target node. -
Configure Puppet: It configures the
puppet.conffile with the necessary settings, including the Puppet server name and, if provided, thecertname. -
Run Bootstrap: Finally, it runs the
puppet::agent::bootstrapBolt plan to initiate the Puppet agent bootstrap process, which handles certificate requests and private key creation.