1.\" Copyright (c) 1983, 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. All advertising materials mentioning features or use of this software 13.\" must display the following acknowledgement: 14.\" This product includes software developed by the University of 15.\" California, Berkeley and its contributors. 16.\" 4. Neither the name of the University nor the names of its contributors 17.\" may be used to endorse or promote products derived from this software 18.\" without specific prior written permission. 19.\" 20.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30.\" SUCH DAMAGE. 31.\" 32.\" @(#)rwhod.8 8.2 (Berkeley) 12/11/93 33.\" $FreeBSD$ 34.\" 35.Dd December 11, 1993 36.Dt RWHOD 8 37.Os 38.Sh NAME 39.Nm rwhod 40.Nd system status server 41.Sh SYNOPSIS 42.Nm 43.Op Fl i 44.Op Fl p 45.Op Fl l 46.Op Fl m Op Ar ttl 47.Sh DESCRIPTION 48The 49.Nm 50utility is the server which maintains the database used by the 51.Xr rwho 1 52and 53.Xr ruptime 1 54programs. Its operation is predicated on the ability to 55.Em broadcast 56or 57.Em multicast 58messages on a network. 59.Pp 60The 61.Nm 62utility operates as both a producer and consumer of status information, 63unless the 64.Fl l 65(listen mode) option is specified, in which case 66it acts as a consumer only. 67As a producer of information it periodically 68queries the state of the system and constructs 69status messages which are broadcasted or multicasted on a network. 70As a consumer of information, it listens for other 71.Nm 72servers' status messages, validating them, then recording 73them in a collection of files located in the directory 74.Pa /var/rwho . 75.Pp 76The following options are available: 77.Bl -tag -width indent 78.It Fl i 79Enable insecure mode, which causes 80.Nm 81to ignore the source port on incoming packets. 82.It Fl p 83Ignore all 84.Dv POINTOPOINT 85interfaces. This is useful if you do not wish to keep dial on demand 86interfaces permanently active. 87.It Fl l 88Enable listen mode, which causes 89.Nm 90to not broadcast any information. 91This allows you to monitor other machines' 92.Nm 93information, without broadcasting your own. 94.It Fl m Op Ar ttl 95Cause 96.Nm 97to use IP multicast (instead of 98broadcast) on all interfaces that have 99the IFF_MULTICAST flag set in their "ifnet" structs 100(excluding the loopback interface). The multicast 101reports are sent with a time-to-live of 1, to prevent 102forwarding beyond the directly-connected subnet(s). 103.Pp 104If the optional 105.Ar ttl 106argument is supplied with the 107.Fl m 108flag, 109.Nm 110will send IP multicast datagrams with a 111time-to-live of 112.Ar ttl , 113via a SINGLE interface rather 114than all interfaces. 115.Ar ttl 116must be between 0 and 11732 (or MAX_MULTICAST_SCOPE). Note that 118.Fl m Ar 1 119is different from 120.Fl m , 121in that 122.Fl m Ar 1 123specifies transmission on one interface only. 124.Pp 125When 126.Fl m 127is used without a 128.Ar ttl 129argument, the program accepts multicast 130.Nm 131reports from all multicast-capable interfaces. If a 132.Ar ttl 133argument is given, it accepts multicast reports from only one interface, the 134one on which reports are sent (which may be controlled via the host's routing 135table). Regardless of the 136.Fl m 137option, the program accepts broadcast or 138unicast reports from all interfaces. Thus, this program will hear the 139reports of old, non-multicasting 140.Nm Ns s , 141but, if multicasting is used, 142those old 143.Nm Ns s 144won't hear the reports generated by this program. 145.El 146.Pp 147The server transmits and receives messages at the port indicated 148in the ``who'' service specification; see 149.Xr services 5 . 150The messages sent and received, are of the form: 151.Bd -literal -offset indent 152struct outmp { 153 char out_line[8]; /* tty name */ 154 char out_name[8]; /* user id */ 155 long out_time; /* time on */ 156}; 157 158struct whod { 159 char wd_vers; 160 char wd_type; 161 char wd_fill[2]; 162 int wd_sendtime; 163 int wd_recvtime; 164 char wd_hostname[32]; 165 int wd_loadav[3]; 166 int wd_boottime; 167 struct whoent { 168 struct outmp we_utmp; 169 int we_idle; 170 } wd_we[1024 / sizeof (struct whoent)]; 171}; 172.Ed 173.Pp 174All fields are converted to network byte order prior to 175transmission. The load averages are as calculated by the 176.Xr w 1 177program, and represent load averages over the 5, 10, and 15 minute 178intervals prior to a server's transmission; they are multiplied by 100 179for representation in an integer. The host name 180included is that returned by the 181.Xr gethostname 3 182system call, with any trailing domain name omitted. 183The array at the end of the message contains information about 184the users logged in to the sending machine. This information 185includes the contents of the 186.Xr utmp 5 187entry for each non-idle terminal line and a value indicating the 188time in seconds since a character was last received on the terminal line. 189.Pp 190Messages received by the 191.Nm rwho 192server are discarded unless they originated at an 193.Nm rwho 194server's port or the 195.Fl i 196option was specified. In addition, if the host's name, as specified 197in the message, contains any unprintable 198.Tn ASCII 199characters, the 200message is discarded. Valid messages received by 201.Nm 202are placed in files named 203.Pa whod.hostname 204in the directory 205.Pa /var/rwho . 206These files contain only the most recent message, in the 207format described above. 208.Pp 209Status messages are generated approximately once every 2103 minutes. 211The 212.Nm 213utility performs an 214.Xr nlist 3 215on 216.Pa /boot/kernel/kernel 217every 30 minutes to guard against 218the possibility that this file is not the system 219image currently operating. 220.Sh SEE ALSO 221.Xr ruptime 1 , 222.Xr rwho 1 223.Sh BUGS 224Status information should be sent only upon request rather than continuously. 225People often interpret the server dying 226or network communication failures 227as a machine going down. 228.Sh HISTORY 229The 230.Nm 231utility appeared in 232.Bx 4.2 . 233