xref: /freebsd/usr.sbin/syslogd/syslogd.8 (revision 884a2a699669ec61e2366e3e358342dbc94be24a)
1.\" Copyright (c) 1983, 1986, 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.\" 4. 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.\"     @(#)syslogd.8	8.1 (Berkeley) 6/6/93
29.\" $FreeBSD$
30.\"
31.Dd May 13, 2008
32.Dt SYSLOGD 8
33.Os
34.Sh NAME
35.Nm syslogd
36.Nd log systems messages
37.Sh SYNOPSIS
38.Nm
39.Op Fl 468ACcdknosuv
40.Op Fl a Ar allowed_peer
41.Op Fl b Ar bind_address
42.Op Fl f Ar config_file
43.Op Fl l Oo Ar mode : Oc Ns Ar path
44.Op Fl m Ar mark_interval
45.Op Fl P Ar pid_file
46.Op Fl p Ar log_socket
47.Sh DESCRIPTION
48The
49.Nm
50utility reads and logs messages to the system console, log files, other
51machines and/or users as specified by its configuration file.
52.Pp
53The options are as follows:
54.Bl -tag -width indent
55.It Fl 4
56Force
57.Nm
58to use IPv4 addresses only.
59.It Fl 6
60Force
61.Nm
62to use IPv6 addresses only.
63.It Fl 8
64Tells
65.Nm
66not to interfere with 8-bit data.  Normally
67.Nm
68will replace C1 control characters
69.Pq ISO 8859 and Unicode characters
70with their
71.Dq M- Ns Em x
72equivalent.
73Note, this option does not change the way
74.Nm
75alters control characters
76.Pq see Xr iscntrl 3 .
77They will always be replaced with their
78.Dq ^ Ns Em x
79equivalent.
80.It Fl A
81Ordinarily,
82.Nm
83tries to send the message to only one address
84even if the host has more than one A or AAAA record.
85If this option is specified,
86.Nm
87tries to send the message to all addresses.
88.It Fl a Ar allowed_peer
89Allow
90.Ar allowed_peer
91to log to this
92.Nm
93using UDP datagrams.
94Multiple
95.Fl a
96options may be specified.
97.Pp
98The
99.Ar allowed_peer
100option may be any of the following:
101.Bl -tag -width "ipaddr/masklen[:service]XX"
102.It Xo
103.Sm off
104.Ar ipaddr
105.No / Ar masklen
106.Op : Ar service
107.Sm on
108.Xc
109Accept datagrams from
110.Ar ipaddr
111(in the usual dotted quad notation) with
112.Ar masklen
113bits being taken into account when doing the address comparison.
114.Ar ipaddr
115can be also IPv6 address by enclosing the address with
116.Ql \&[
117and
118.Ql \&] .
119If specified,
120.Ar service
121is the name or number of an UDP service (see
122.Xr services 5 )
123the source packet must belong to.
124A
125.Ar service
126of
127.Ql \&*
128allows packets being sent from any UDP port.
129The default
130.Ar service
131is
132.Ql syslog .
133If
134.Ar ipaddr
135is IPv4 address, a missing
136.Ar masklen
137will be substituted by the historic class A or class B netmasks if
138.Ar ipaddr
139belongs into the address range of class A or B, respectively, or
140by 24 otherwise.
141If
142.Ar ipaddr
143is IPv6 address, a missing
144.Ar masklen
145will be substituted by 128.
146.It Xo
147.Sm off
148.Ar domainname Op : Ar service
149.Sm on
150.Xc
151Accept datagrams where the reverse address lookup yields
152.Ar domainname
153for the sender address.
154The meaning of
155.Ar service
156is as explained above.
157.It Xo
158.Sm off
159.No * Ar domainname Op : Ar service
160.Sm on
161.Xc
162Same as before, except that any source host whose name
163.Em ends
164in
165.Ar domainname
166will get permission.
167.El
168.Pp
169The
170.Fl a
171options are ignored if the
172.Fl s
173option is also specified.
174.It Xo
175.Fl b
176.Sm off
177.Ar bind_address Op : Ar service
178.Sm on
179.Xc
180.It Xo
181.Fl b
182.Sm off
183.Li : Ar service
184.Sm on
185.Xc
186Bind to a specific address and/or port.
187The address can be specified as a hostname,
188and the port as a service name.
189If an IPv6 address is specified, it should be enclosed with
190.Ql \&[
191and
192.Ql \&] .
193The default
194.Ar service
195is
196.Ql syslog .
197.It Fl C
198Create log files that do not exist (permission is set to
199.Li 0600 ) .
200.It Fl c
201Disable the compression of repeated instances of the same line
202into a single line of the form
203.Dq Li "last message repeated N times"
204when the output is a pipe to another program.
205If specified twice, disable this compression in all cases.
206.It Fl d
207Put
208.Nm
209into debugging mode.
210This is probably only of use to developers working on
211.Nm .
212.It Fl f
213Specify the pathname of an alternate configuration file;
214the default is
215.Pa /etc/syslog.conf .
216.It Fl k
217Disable the translation of
218messages received with facility
219.Dq kern
220to facility
221.Dq user .
222Usually the
223.Dq kern
224facility is reserved for messages read directly from
225.Pa /dev/klog .
226.It Fl m
227Select the number of minutes between
228.Dq mark
229messages; the default is 20 minutes.
230.It Fl n
231Disable dns query for every request.
232.It Fl o
233Prefix kernel messages with the full kernel boot file as determined by
234.Xr getbootfile 3 .
235Without this, the kernel message prefix is always
236.Dq Li kernel: .
237.It Fl p
238Specify the pathname of an alternate log socket to be used instead;
239the default is
240.Pa /var/run/log .
241.It Fl P
242Specify an alternative file in which to store the process ID.
243The default is
244.Pa /var/run/syslog.pid .
245.It Fl S
246Specify the pathname of an alternate log socket for privileged
247applications to be used instead; the default is
248.Pa /var/run/logpriv .
249.It Fl l
250Specify a location where
251.Nm
252should place an additional log socket.
253The primary use for this is to place additional log sockets in
254.Pa /var/run/log
255of various chroot filespaces.
256File permissions for socket can be specified in octal representation
257before socket name, delimited with a colon.
258Path to socket location must be absolute.
259.It Fl s
260Operate in secure mode.
261Do not log messages from remote machines.
262If
263specified twice, no network socket will be opened at all, which also
264disables logging to remote machines.
265.It Fl T
266Always use the local time and date for messages received from the network,
267instead of the timestamp field supplied in the message by the remote host.
268This is useful if some of the originating hosts can't keep time properly
269or are unable to generate a correct timestamp.
270.It Fl u
271Unique priority logging.
272Only log messages at the specified priority.
273Without this option, messages at the stated priority or higher are logged.
274This option changes the default comparison from
275.Dq =>
276to
277.Dq = .
278.It Fl v
279Verbose logging.
280If specified once, the numeric facility and priority are
281logged with each locally-written message.
282If specified more than once,
283the names of the facility and priority are logged with each locally-written
284message.
285.El
286.Pp
287The
288.Nm
289utility reads its configuration file when it starts up and whenever it
290receives a hangup signal.
291For information on the format of the configuration file,
292see
293.Xr syslog.conf 5 .
294.Pp
295The
296.Nm
297utility reads messages from the
298.Ux
299domain sockets
300.Pa /var/run/log
301and
302.Pa /var/run/logpriv ,
303from an Internet domain socket specified in
304.Pa /etc/services ,
305and from the special device
306.Pa /dev/klog
307(to read kernel messages).
308.Pp
309The
310.Nm
311utility creates its process ID file,
312by default
313.Pa /var/run/syslog.pid ,
314and stores its process
315ID there.
316This can be used to kill or reconfigure
317.Nm .
318.Pp
319The message sent to
320.Nm
321should consist of a single line.
322The message can contain a priority code, which should be a preceding
323decimal number in angle braces, for example,
324.Sq Aq 5 .
325This priority code should map into the priorities defined in the
326include file
327.In sys/syslog.h .
328.Pp
329For security reasons,
330.Nm
331will not append to log files that do not exist (unless
332.Fl C
333option is specified);
334therefore, they must be created manually before running
335.Nm .
336.Pp
337The date and time are taken from the received message.
338If the format of the timestamp field is incorrect,
339time obtained from the local host is used instead.
340This can be overriden by the
341.Fl T
342flag.
343.Sh FILES
344.Bl -tag -width /var/run/syslog.pid -compact
345.It Pa /etc/syslog.conf
346configuration file
347.It Pa /var/run/syslog.pid
348default process ID file
349.It Pa /var/run/log
350name of the
351.Ux
352domain datagram log socket
353.It Pa /var/run/logpriv
354.Ux
355socket for privileged applications
356.It Pa /dev/klog
357kernel log device
358.El
359.Sh SEE ALSO
360.Xr logger 1 ,
361.Xr syslog 3 ,
362.Xr services 5 ,
363.Xr syslog.conf 5 ,
364.Xr newsyslog 8
365.Sh HISTORY
366The
367.Nm
368utility appeared in
369.Bx 4.3 .
370.Pp
371The
372.Fl a ,
373.Fl s ,
374.Fl u ,
375and
376.Fl v
377options are
378.Fx 2.2
379extensions.
380.Sh BUGS
381The ability to log messages received in UDP packets is equivalent to
382an unauthenticated remote disk-filling service, and should probably be
383disabled by default.
384Some sort of
385.No inter- Ns Nm syslogd
386authentication mechanism ought to be worked out.
387To prevent the worst
388abuse, use of the
389.Fl a
390option is therefore highly recommended.
391.Pp
392The
393.Fl a
394matching algorithm does not pretend to be very efficient; use of numeric
395IP addresses is faster than domain name comparison.
396Since the allowed
397peer list is being walked linearly, peer groups where frequent messages
398are being anticipated from should be put early into the
399.Fl a
400list.
401.Pp
402The log socket was moved from
403.Pa /dev
404to ease the use of a read-only root file system.
405This may confuse
406some old binaries so that a symbolic link might be used for a
407transitional period.
408