]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.sbin/syslogd/syslog.conf.5
Update apr-util to 1.6.1. See contrib/apr-util/CHANGES for a summary of
[FreeBSD/FreeBSD.git] / usr.sbin / syslogd / syslog.conf.5
1 .\" Copyright (c) 1990, 1991, 1993
2 .\"     The Regents of the University of California.  All rights reserved.
3 .\"
4 .\" Redistribution and use in source and binary forms, with or without
5 .\" modification, are permitted provided that the following conditions
6 .\" are met:
7 .\" 1. Redistributions of source code must retain the above copyright
8 .\"    notice, this list of conditions and the following disclaimer.
9 .\" 2. Redistributions in binary form must reproduce the above copyright
10 .\"    notice, this list of conditions and the following disclaimer in the
11 .\"    documentation and/or other materials provided with the distribution.
12 .\" 3. Neither the name of the University nor the names of its contributors
13 .\"    may be used to endorse or promote products derived from this software
14 .\"    without specific prior written permission.
15 .\"
16 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
17 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
20 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 .\" SUCH DAMAGE.
27 .\"
28 .\"     @(#)syslog.conf.5       8.1 (Berkeley) 6/9/93
29 .\" $FreeBSD$
30 .\"
31 .Dd March 26, 2020
32 .Dt SYSLOG.CONF 5
33 .Os
34 .Sh NAME
35 .Nm syslog.conf
36 .Nd
37 .Xr syslogd 8
38 configuration file
39 .Sh DESCRIPTION
40 The
41 .Nm
42 file is the configuration file for the
43 .Xr syslogd 8
44 program.
45 It consists of
46 blocks of lines separated by
47 .Em program ,
48 .Em hostname
49 or
50 .Em property-based filter
51 specifications (separations appear alone on their lines),
52 with each line containing two fields: the
53 .Em selector
54 field which specifies the types of messages and priorities to which the
55 line applies, and an
56 .Em action
57 field which specifies the action to be taken if a message
58 .Xr syslogd 8
59 receives matches the selection criteria.
60 The
61 .Em selector
62 field is separated from the
63 .Em action
64 field by one or more tab characters or spaces.
65 .Pp
66 A special
67 .Em include
68 keyword can be used to include all files with names ending in '.conf' and not
69 beginning with a '.' contained in the directory following the keyword.
70 This keyword can only be used in the first level configuration file.
71 .Pp
72 Note that if you use spaces as separators, your
73 .Nm
74 might be incompatible with other Unices or Unix-like systems.
75 This functionality was added for ease of configuration
76 (e.g.\& it is possible to cut-and-paste into
77 .Nm ) ,
78 and to avoid possible mistakes.
79 This change however preserves
80 backwards compatibility with the old style of
81 .Nm
82 (i.e., tab characters only).
83 .Pp
84 The
85 .Em selectors
86 are encoded as a
87 .Em facility ,
88 a period
89 .Pq Dq \&. ,
90 an optional set of comparison flags
91 .Pq Oo \&! Oc Op <=> ,
92 and a
93 .Em level ,
94 with no intervening white-space.
95 Both the
96 .Em facility
97 and the
98 .Em level
99 are case insensitive.
100 .Pp
101 The
102 .Em facility
103 describes the part of the system generating the message, and is one of
104 the following keywords:
105 .Cm auth , authpriv , console , cron , daemon , ftp , kern , lpr ,
106 .Cm mail , mark , news , ntp , security , syslog , user , uucp ,
107 and
108 .Cm local0
109 through
110 .Cm local7 .
111 These keywords (with the exception of mark) correspond to
112 similar
113 .Dq Dv LOG_
114 values specified to the
115 .Xr openlog 3
116 and
117 .Xr syslog 3
118 library routines.
119 .Pp
120 The
121 .Em comparison flags
122 may be used to specify exactly what is logged.
123 The default comparison is
124 .Dq =>
125 (or, if you prefer,
126 .Dq >= ) ,
127 which means that messages from the specified
128 .Em facility
129 list, and of a priority
130 level equal to or greater than
131 .Em level
132 will be logged.
133 Comparison flags beginning with
134 .Dq Li \&!
135 will have their logical sense inverted.
136 Thus
137 .Dq !=info
138 means all levels except info and
139 .Dq !notice
140 has the same meaning as
141 .Dq <notice .
142 .Pp
143 The
144 .Em level
145 describes the severity of the message, and is a keyword from the
146 following ordered list (higher to lower):
147 .Cm emerg , crit , alert , err , warning , notice , info
148 and
149 .Cm debug .
150 These keywords correspond to
151 similar
152 .Dq Dv LOG_
153 values specified to the
154 .Xr syslog 3
155 library routine.
156 .Pp
157 Each block of lines is separated from the previous block by a
158 .Em program ,
159 .Em hostname
160 or
161 .Em property-based filter
162 specification.
163 A block will only log messages corresponding to the most recent
164 .Em program ,
165 .Em hostname
166 and
167 .Em property-based filter
168 specifications given.
169 Thus, with a block which selects
170 .Ql ppp
171 as the
172 .Em program ,
173 directly followed by a block that selects messages from the
174 .Em hostname
175 .Ql dialhost ,
176 the second block will only log messages
177 from the
178 .Xr ppp 8
179 program on dialhost.
180 .Pp
181 A
182 .Em program
183 specification is a line beginning with
184 .Ql #!prog
185 or
186 .Ql !prog
187 (the former is for compatibility with the previous syslogd, if one is sharing
188 .Nm
189 files, for example)
190 and the following blocks will be associated with calls to
191 .Xr syslog 3
192 from that specific program.
193 A
194 .Em program
195 specification for
196 .Ql foo
197 will also match any message logged by the kernel with the prefix
198 .Ql "foo: " .
199 The
200 .Ql #!+prog
201 or
202 .Ql !+prog
203 specification works just like the previous one,
204 and the
205 .Ql #!-prog
206 or
207 .Ql !-prog
208 specification will match any message but the ones from that
209 program.
210 Multiple programs may be listed, separated by commas:
211 .Ql !prog1,prog2
212 matches messages from either program, while
213 .Ql !-prog1,prog2
214 matches all messages but those from
215 .Ql prog1
216 or
217 .Ql prog2 .
218 .Pp
219 A
220 .Em hostname
221 specification of the form
222 .Ql #+hostname
223 or
224 .Ql +hostname
225 means the following blocks will be applied to messages
226 received from the specified hostname.
227 Alternatively, the
228 .Em hostname
229 specification
230 .Ql #-hostname
231 or
232 .Ql -hostname
233 causes the following blocks to be applied to messages
234 from any host but the one specified.
235 If the hostname is given as
236 .Ql @ ,
237 the local hostname will be used.
238 As for program specifications, multiple comma-separated
239 values may be specified for hostname specifications.
240 .Pp
241 A
242 .Em property-based filter
243 specification is a line beginning with
244 .Ql #:
245 or
246 .Ql \&:
247 and the following blocks will be applied only when filter value
248 matches given filter propertie's value. See
249 .Sx PROPERTY-BASED FILTERS
250 section for more details.
251 .Pp
252 A
253 .Em program ,
254 .Em hostname
255 or
256 .Em property-based filter
257 specification may be reset by giving
258 .Ql *
259 as an argument.
260 .Pp
261 See
262 .Xr syslog 3
263 for further descriptions of both the
264 .Em facility
265 and
266 .Em level
267 keywords and their significance.
268 It is preferred that selections be made on
269 .Em facility
270 rather than
271 .Em program ,
272 since the latter can easily vary in a networked environment.
273 In some cases,
274 though, an appropriate
275 .Em facility
276 simply does not exist.
277 .Pp
278 If a received message matches the specified
279 .Em facility
280 and is of the specified
281 .Em level
282 .Em (or a higher level) ,
283 and the first word in the message after the date matches the
284 .Em program ,
285 the action specified in the
286 .Em action
287 field will be taken.
288 .Pp
289 Multiple
290 .Em selectors
291 may be specified for a single
292 .Em action
293 by separating them with semicolon
294 .Pq Dq \&;
295 characters.
296 It is important to note, however, that each
297 .Em selector
298 can modify the ones preceding it.
299 .Pp
300 Multiple
301 .Em facilities
302 may be specified for a single
303 .Em level
304 by separating them with comma
305 .Pq Dq \&,
306 characters.
307 .Pp
308 An asterisk
309 .Pq Dq *
310 can be used to specify all
311 .Em facilities ,
312 all
313 .Em levels ,
314 or all
315 .Em programs .
316 .Pp
317 The special
318 .Em facility
319 .Dq mark
320 receives a message at priority
321 .Dq info
322 every 20 minutes
323 (see
324 .Xr syslogd 8 ) .
325 This is not enabled by a
326 .Em facility
327 field containing an asterisk.
328 .Pp
329 The special
330 .Em level
331 .Dq none
332 disables a particular
333 .Em facility .
334 .Pp
335 The
336 .Em action
337 field of each line specifies the action to be taken when the
338 .Em selector
339 field selects a message.
340 There are five forms:
341 .Bl -bullet
342 .It
343 A pathname (beginning with a leading slash).
344 Selected messages are appended to the file.
345 .Pp
346 To ensure that kernel messages are written to disk promptly,
347 .Nm
348 calls
349 .Xr fsync 2
350 after writing messages from the kernel.
351 Other messages are not synced explicitly.
352 You may prefix a pathname with the minus sign,
353 .Dq - ,
354 to forego syncing the specified file after every kernel message.
355 Note that you might lose information if the system crashes
356 immediately following a write attempt.
357 Nevertheless, using the
358 .Dq -
359 option may improve performance,
360 especially if the kernel is logging many messages.
361 .It
362 A hostname (preceded by an at
363 .Pq Dq @
364 sign).
365 Selected messages are forwarded to the
366 .Xr syslogd 8
367 program on the named host.
368 If a port number is added after a colon
369 .Pq Ql :\&
370 then that port will be used as the destination port
371 rather than the usual syslog port.
372 IPv6 addresses can be used
373 by surrounding the address portion with
374 square brackets
375 .Po
376 .Ql [\&
377 and
378 .Ql ]\&
379 .Pc .
380 .It
381 A comma separated list of users.
382 Selected messages are written to those users
383 if they are logged in.
384 .It
385 An asterisk.
386 Selected messages are written to all logged-in users.
387 .It
388 A vertical bar
389 .Pq Dq \&| ,
390 followed by a command to pipe the selected
391 messages to.
392 The command is passed to
393 .Xr sh 1
394 for evaluation, so usual shell metacharacters or input/output
395 redirection can occur.
396 (Note however that redirecting
397 .Xr stdio 3
398 buffered output from the invoked command can cause additional delays,
399 or even lost output data in case a logging subprocess exited with a
400 signal.)
401 The command itself runs with
402 .Em stdout
403 and
404 .Em stderr
405 redirected to
406 .Pa /dev/null .
407 Upon receipt of a
408 .Dv SIGHUP ,
409 .Xr syslogd 8
410 will close the pipe to the process.
411 If the process did not exit
412 voluntarily, it will be sent a
413 .Dv SIGTERM
414 signal after a grace period of up to 60 seconds.
415 .Pp
416 The command will only be started once data arrives that should be piped
417 to it.
418 If it exited later, it will be restarted as necessary.
419 So if it
420 is desired that the subprocess should get exactly one line of input only
421 (which can be very resource-consuming if there are a lot of messages
422 flowing quickly), this can be achieved by exiting after just one line of
423 input.
424 If necessary, a script wrapper can be written to this effect.
425 .Pp
426 Unless the command is a full pipeline, it is probably useful to
427 start the command with
428 .Em exec
429 so that the invoking shell process does not wait for the command to
430 complete.
431 Warning: the process is started under the UID invoking
432 .Xr syslogd 8 ,
433 normally the superuser.
434 .El
435 .Pp
436 Blank lines and lines whose first non-blank character is a hash
437 .Pq Dq #
438 character are ignored.
439 If
440 .Ql #
441 is placed in the middle of the line, the
442 .Ql #
443 character and the rest of the line after it is ignored.
444 To prevent special meaning, the
445 .Ql #
446 character may be escaped with
447 .Ql \e ;
448 in this case preceding
449 .Ql \e
450 is removed and
451 .Ql #
452 is treated as an ordinary character.
453 .Sh PROPERTY-BASED FILTERS
454 .Em program ,
455 .Em hostname
456 specifications performs exact match filtering against explicit field only.
457 .Em Property-based filters
458 feature substring and regular expressions (see
459 .Xr re_format 7 )
460 matching against various message attributes.
461 Filter specification starts with
462 .Ql #:
463 or
464 .Ql \&:
465 followed by three comma-separated fields
466 .Em property , operator , \&"value\&" .
467 Value must be double-quoted. A double quote and backslash must be escaped by
468 a backslash.
469 .Pp
470 Following
471 .Em properties
472 are supported as test value:
473 .Pp
474 .Bl -bullet -compact
475 .It
476 .Ql msg
477 - body of the message received.
478 .It
479 .Ql programname
480 - program name sent the message
481 .It
482 .Ql hostname
483 - hostname of message's originator
484 .It
485 .Ql source
486 - an alias for hostname
487 .El
488 .Pp
489 Operator specifies a comparison function between
490 .Em propertie's
491  value against filter's value.
492 Possible operators:
493 .Pp
494 .Bl -bullet -compact
495 .It
496 .Ql contains
497 - true if filter value is found as a substring of
498 .Em property
499 .It
500 .Ql isequal
501 - true if filter value is equal to
502 .Em property
503 .It
504 .Ql startswith
505 - true if property starts with filter value
506 .It
507 .Ql regex
508 - true if property matches basic regular expression defined in filter value
509 .It
510 .Ql ereregex
511 - true if property matches extended regular expression defined in filter value
512 .El
513 .Pp
514 Operator may be prefixed by
515 .Pp
516 .Bl -bullet -compact
517 .It
518 .Ql \&!
519 - to invert compare logic
520 .It
521 .Ql icase_
522 - to make comparison function case insensitive
523 .El
524 .Pp
525 .Sh IMPLEMENTATION NOTES
526 The
527 .Dq kern
528 facility is usually reserved for messages
529 generated by the local kernel.
530 Other messages logged with facility
531 .Dq kern
532 are usually translated to facility
533 .Dq user .
534 This translation can be disabled;
535 see
536 .Xr syslogd 8
537 for details.
538 .Sh FILES
539 .Bl -tag -width /etc/syslog.conf -compact
540 .It Pa /etc/syslog.conf
541 .Xr syslogd 8
542 configuration file
543 .El
544 .Sh EXAMPLES
545 A configuration file might appear as follows:
546 .Bd -literal
547 # Log all kernel messages, authentication messages of
548 # level notice or higher, and anything of level err or
549 # higher to the console.
550 # Don't log private authentication messages!
551 *.err;kern.*;auth.notice;authpriv.none;mail.crit        /dev/console
552
553 # Log anything (except mail) of level info or higher.
554 # Don't log private authentication messages!
555 *.info;mail.none;authpriv.none          /var/log/messages
556
557 # Log daemon messages at debug level only
558 daemon.=debug                                           /var/log/daemon.debug
559
560 # The authpriv file has restricted access.
561 authpriv.*                                              /var/log/secure
562
563 # Log all the mail messages in one place.
564 mail.*                                                  /var/log/maillog
565
566 # Everybody gets emergency messages, plus log them on another
567 # machine.
568 *.emerg                                                 *
569 *.emerg                                                 @arpa.berkeley.edu
570
571 # Root and Eric get alert and higher messages.
572 *.alert                                                 root,eric
573
574 # Save mail and news errors of level err and higher in a
575 # special file.
576 uucp,news.crit                                          /var/log/spoolerr
577
578 # Pipe all authentication messages to a filter.
579 auth.*                                  |exec /usr/local/sbin/authfilter
580
581 # Log all security messages to a separate file.
582 security.*                                              /var/log/security
583
584 # Log all writes to /dev/console to a separate file.
585 console.*                                               /var/log/console.log
586
587 # Save ftpd transactions along with mail and news
588 !ftpd
589 *.*                                                     /var/log/spoolerr
590
591 # Log ipfw messages without syncing after every message.
592 !ipfw
593 *.*                                                     -/var/log/ipfw
594
595 # Log ipfw messages with "Deny" in the message body.
596 :msg, contains, ".*Deny.*"
597 *.*                                                     /var/log/ipfw.deny
598
599 # Reset program name filtering
600 !*
601
602 # Log messages from bird or bird6 into one file
603 :processname, regex, "^bird6?$"
604 *.*                                                     /var/log/bird-all.log
605
606 # Log messages from servers in racks 10-19 in multiple locations, case insensitive
607 :hostname, icase_ereregex, "^server-(dcA|podB|cdn)-rack1[0-9]{2}\\..*"
608 *.*                                                     /var/log/racks10..19.log
609 .Ed
610 .Sh SEE ALSO
611 .Xr syslog 3 ,
612 .Xr syslogd 8
613 .Sh BUGS
614 The effects of multiple
615 .Em selectors
616 are sometimes not intuitive.
617 For example
618 .Dq mail.crit,*.err
619 will select
620 .Dq mail
621 facility messages at the level of
622 .Dq err
623 or higher, not at the level of
624 .Dq crit
625 or higher.
626 .Pp
627 In networked environments, note that not all operating systems
628 implement the same set of facilities.
629 The facilities
630 authpriv, cron, ftp, and ntp that are known to this implementation
631 might be absent on the target system.
632 Even worse, DEC UNIX uses
633 facility number 10 (which is authpriv in this implementation) to
634 log events for their AdvFS file system.