1PUPPET-AGENT(8) Puppet manual PUPPET-AGENT(8)
2
3
4
6 puppet-agent - The puppet agent daemon
7
9 Retrieves the client configuration from the Puppet master and applies
10 it to the local host.
11
12 This service may be run as a daemon, run periodically using cron (or
13 something similar), or run interactively for testing purposes.
14
16 puppet agent [--certname NAME] [-D|--daemonize|--no-daemonize]
17 [-d|--debug] [--detailed-exitcodes] [--digest DIGEST] [--disable [MES‐
18 SAGE]] [--enable] [--fingerprint] [-h|--help] [-l|--logdest sys‐
19 log|eventlog|ABS FILEPATH|console] [--serverport PORT] [--noop]
20 [-o|--onetime] [--sourceaddress IP_ADDRESS] [-t|--test] [-v|--verbose]
21 [-V|--version] [-w|--waitforcert SECONDS]
22
24 This is the main puppet client. Its job is to retrieve the local ma‐
25 chine´s configuration from a remote server and apply it. In order to
26 successfully communicate with the remote server, the client must have a
27 certificate signed by a certificate authority that the server trusts;
28 the recommended method for this, at the moment, is to run a certificate
29 authority as part of the puppet server (which is the default). The
30 client will connect and request a signed certificate, and will continue
31 connecting until it receives one.
32
33 Once the client has a signed certificate, it will retrieve its configu‐
34 ration and apply it.
35
37 ´puppet agent´ does its best to find a compromise between interactive
38 use and daemon use. If you run it with no arguments and no configura‐
39 tion, it goes into the background, attempts to get a signed certifi‐
40 cate, and retrieves and applies its configuration every 30 minutes.
41
42 Some flags are meant specifically for interactive use --- in particu‐
43 lar, ´test´, ´tags´ and ´fingerprint´ are useful.
44
45 ´--test´ runs once in the foreground with verbose logging, then exits.
46 It also exits if it can´t get a valid catalog. --test includes the
47 ´--detailed-exitcodes´ option by default and exits with one of the fol‐
48 lowing exit codes:
49
50 • 0: The run succeeded with no changes or failures; the system was
51 already in the desired state.
52
53 • 1: The run failed, or wasn´t attempted due to another run already
54 in progress.
55
56 • 2: The run succeeded, and some resources were changed.
57
58 • 4: The run succeeded, and some resources failed.
59
60 • 6: The run succeeded, and included both changes and failures.
61
62
63
64 ´--tags´ allows you to specify what portions of a configuration you
65 want to apply. Puppet elements are tagged with all of the class or def‐
66 inition names that contain them, and you can use the ´tags´ flag to
67 specify one of these names, causing only configuration elements con‐
68 tained within that class or definition to be applied. This is very use‐
69 ful when you are testing new configurations --- for instance, if you
70 are just starting to manage ´ntpd´, you would put all of the new ele‐
71 ments into an ´ntpd´ class, and call puppet with ´--tags ntpd´, which
72 would only apply that small portion of the configuration during your
73 testing, rather than applying the whole thing.
74
75 ´--fingerprint´ is a one-time flag. In this mode ´puppet agent´ runs
76 once and displays on the console (and in the log) the current certifi‐
77 cate (or certificate request) fingerprint. Providing the ´--digest´ op‐
78 tion allows you to use a different digest algorithm to generate the
79 fingerprint. The main use is to verify that before signing a certifi‐
80 cate request on the master, the certificate request the master received
81 is the same as the one the client sent (to prevent against
82 man-in-the-middle attacks when signing certificates).
83
84 ´--skip_tags´ is a flag used to filter resources. If this is set, then
85 only resources not tagged with the specified tags will be applied. Val‐
86 ues must be comma-separated.
87
89 Note that any Puppet setting that´s valid in the configuration file is
90 also a valid long argument. For example, ´server´ is a valid setting,
91 so you can specify ´--server servername´ as an argument. Boolean set‐
92 tings accept a ´--no-´ prefix to turn off a behavior, translating into
93 ´--setting´ and ´--no-setting´ pairs, such as --daemonize and --no-dae‐
94 monize.
95
96 See the configuration file documentation at https://pup‐
97 pet.com/docs/puppet/latest/configuration.html for the full list of ac‐
98 ceptable settings. A commented list of all settings can also be gener‐
99 ated by running puppet agent with ´--genconfig´.
100
101 • --certname: Set the certname (unique ID) of the client. The master
102 reads this unique identifying string, which is usually set to the
103 node´s fully-qualified domain name, to determine which configura‐
104 tions the node will receive. Use this option to debug setup prob‐
105 lems or implement unusual node identification schemes. (This is a
106 Puppet setting, and can go in puppet.conf.)
107
108 • --daemonize: Send the process into the background. This is the de‐
109 fault. (This is a Puppet setting, and can go in puppet.conf. Note
110 the special ´no-´ prefix for boolean settings on the command line.)
111
112 • --no-daemonize: Do not send the process into the background. (This
113 is a Puppet setting, and can go in puppet.conf. Note the special
114 ´no-´ prefix for boolean settings on the command line.)
115
116 • --debug: Enable full debugging.
117
118 • --detailed-exitcodes: Provide extra information about the run via
119 exit codes; works only if ´--test´ or ´--onetime´ is also speci‐
120 fied. If enabled, ´puppet agent´ uses the following exit codes:
121
122 0: The run succeeded with no changes or failures; the system was
123 already in the desired state.
124
125 1: The run failed, or wasn´t attempted due to another run already
126 in progress.
127
128 2: The run succeeded, and some resources were changed.
129
130 4: The run succeeded, and some resources failed.
131
132 6: The run succeeded, and included both changes and failures.
133
134 • --digest: Change the certificate fingerprinting digest algorithm.
135 The default is SHA256. Valid values depends on the version of
136 OpenSSL installed, but will likely contain MD5, MD2, SHA1 and
137 SHA256.
138
139 • --disable: Disable working on the local system. This puts a lock
140 file in place, causing ´puppet agent´ not to work on the system un‐
141 til the lock file is removed. This is useful if you are testing a
142 configuration and do not want the central configuration to override
143 the local state until everything is tested and committed.
144
145 Disable can also take an optional message that will be reported by
146 the ´puppet agent´ at the next disabled run.
147
148 ´puppet agent´ uses the same lock file while it is running, so no
149 more than one ´puppet agent´ process is working at a time.
150
151 ´puppet agent´ exits after executing this.
152
153 • --enable: Enable working on the local system. This removes any lock
154 file, causing ´puppet agent´ to start managing the local system
155 again However, it continues to use its normal scheduling, so it
156 might not start for another half hour.
157
158 ´puppet agent´ exits after executing this.
159
160 • --evaltrace: Logs each resource as it is being evaluated. This al‐
161 lows you to interactively see exactly what is being done. (This is
162 a Puppet setting, and can go in puppet.conf. Note the special ´no-´
163 prefix for boolean settings on the command line.)
164
165 • --fingerprint: Display the current certificate or certificate sign‐
166 ing request fingerprint and then exit. Use the ´--digest´ option to
167 change the digest algorithm used.
168
169 • --help: Print this help message
170
171 • --job-id: Attach the specified job id to the catalog request and
172 the report used for this agent run. This option only works when
173 ´--onetime´ is used. When using Puppet Enterprise this flag should
174 not be used as the orchestrator sets the job-id for you and it must
175 be unique.
176
177 • --logdest: Where to send log messages. Choose between ´syslog´ (the
178 POSIX syslog service), ´eventlog´ (the Windows Event Log), ´con‐
179 sole´, or the path to a log file. If debugging or verbosity is en‐
180 abled, this defaults to ´console´. Otherwise, it defaults to ´sys‐
181 log´ on POSIX systems and ´eventlog´ on Windows. Multiple destina‐
182 tions can be set using a comma separated list (eg: /path/file1,con‐
183 sole,/path/file2)"
184
185 A path ending with ´.json´ will receive structured output in JSON
186 format. The log file will not have an ending ´]´ automatically
187 written to it due to the appending nature of logging. It must be
188 appended manually to make the content valid JSON.
189
190 A path ending with ´.jsonl´ will receive structured output in JSON
191 Lines format.
192
193 • --masterport: The port on which to contact the Puppet Server. (This
194 is a Puppet setting, and can go in puppet.conf. Deprecated in favor
195 of the ´serverport´ setting.)
196
197 • --noop: Use ´noop´ mode where the daemon runs in a no-op or dry-run
198 mode. This is useful for seeing what changes Puppet would make
199 without actually executing the changes. (This is a Puppet setting,
200 and can go in puppet.conf. Note the special ´no-´ prefix for bool‐
201 ean settings on the command line.)
202
203 • --onetime: Run the configuration once. Runs a single (normally dae‐
204 monized) Puppet run. Useful for interactively running puppet agent
205 when used in conjunction with the --no-daemonize option. (This is a
206 Puppet setting, and can go in puppet.conf. Note the special ´no-´
207 prefix for boolean settings on the command line.)
208
209 • --serverport: The port on which to contact the Puppet Server. (This
210 is a Puppet setting, and can go in puppet.conf.)
211
212 • --sourceaddress: Set the source IP address for transactions. This
213 defaults to automatically selected. (This is a Puppet setting, and
214 can go in puppet.conf.)
215
216 • --test: Enable the most common options used for testing. These are
217 ´onetime´, ´verbose´, ´no-daemonize´, ´no-usecacheonfailure´, ´de‐
218 tailed-exitcodes´, ´no-splay´, and ´show_diff´.
219
220 • --trace Prints stack traces on some errors. (This is a Puppet set‐
221 ting, and can go in puppet.conf. Note the special ´no-´ prefix for
222 boolean settings on the command line.)
223
224 • --verbose: Turn on verbose reporting.
225
226 • --version: Print the puppet version number and exit.
227
228 • --waitforcert: This option only matters for daemons that do not yet
229 have certificates and it is enabled by default, with a value of 120
230 (seconds). This causes ´puppet agent´ to connect to the server ev‐
231 ery 2 minutes and ask it to sign a certificate request. This is
232 useful for the initial setup of a puppet client. You can turn off
233 waiting for certificates by specifying a time of 0. (This is a Pup‐
234 pet setting, and can go in puppet.conf.)
235
236 • --write_catalog_summary After compiling the catalog saves the re‐
237 source list and classes list to the node in the state directory
238 named classes.txt and resources.txt (This is a Puppet setting, and
239 can go in puppet.conf.)
240
241
242
244 $ puppet agent --server puppet.domain.com
245
247 Puppet agent accepts the following signals:
248
249 SIGHUP Restart the puppet agent daemon.
250
251 SIGINT and SIGTERM
252 Shut down the puppet agent daemon.
253
254 SIGUSR1
255 Immediately retrieve and apply configurations from the puppet
256 master.
257
258 SIGUSR2
259 Close file descriptors for log files and reopen them. Used with
260 logrotate.
261
263 Luke Kanies
264
266 Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 Li‐
267 cense
268
269
270
271Puppet, Inc. October 2023 PUPPET-AGENT(8)