The codedir is the main directory for Puppet code and data. It is used by Puppet master and Puppet apply, but not by Puppet agent. It contains environments (which contain your manifests and modules), a global modules directory for all environments, and your Hiera data and configuration.
Location
-
*nix:
/etc/puppetlabs/code
-
*nix non-root users:
~/.puppetlabs/etc/code
-
Windows:
%PROGRAMDATA%\PuppetLabs\code
(usuallyC:\ProgramData\PuppetLabs\code
)
When Puppet is running as root, as a Windows user with administrator privileges, or as the puppet
user, it uses a system-wide codedir. When running as a non-root user, it uses a codedir in that user's home directory.
When running Puppet commands and services as root
or puppet
, use the
system codedir. To use the same codedir as the Puppet
agent, or Puppet master, run admin commands such
as puppet module
with sudo
.
codedir
setting in your puppet.conf
file, such as: puppet.conf
, and instead uses the jruby-puppet.master-code-dir
setting in puppetserver.conf
. When using a non-default codedir, you must change both settings.$codedir
Interpolation of puppet.conf
settings by using the $codedir
variable in the value. For example, the $codedir
variable is used as part of the value for the environmentpath
setting: This allows you to avoid absolute paths in your settings and keep your Puppet-related files together.
Contents
The codedir contains environments, including manifests and modules, a global modules directory for all environments, and Hiera data.
-
environments
: Contains alternate versions of themodules
andmanifests
directories, to enable code changes to be tested on smaller sets of nodes before entering production. -
modules
: The main directory for modules.