xref: /minix/usr.bin/netstat/netstat.1 (revision 00b67f09)
1.\"	$NetBSD: netstat.1,v 1.72 2015/03/23 18:33:17 roy Exp $
2.\"
3.\" Copyright (c) 1983, 1990, 1992, 1993
4.\"	The Regents of the University of California.  All rights reserved.
5.\"
6.\" Redistribution and use in source and binary forms, with or without
7.\" modification, are permitted provided that the following conditions
8.\" are met:
9.\" 1. Redistributions of source code must retain the above copyright
10.\"    notice, this list of conditions and the following disclaimer.
11.\" 2. Redistributions in binary form must reproduce the above copyright
12.\"    notice, this list of conditions and the following disclaimer in the
13.\"    documentation and/or other materials provided with the distribution.
14.\" 3. Neither the name of the University nor the names of its contributors
15.\"    may be used to endorse or promote products derived from this software
16.\"    without specific prior written permission.
17.\"
18.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
19.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
22.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28.\" SUCH DAMAGE.
29.\"
30.\"	@(#)netstat.1	8.8 (Berkeley) 4/18/94
31.\"
32.Dd March 19, 2015
33.Dt NETSTAT 1
34.Os
35.Sh NAME
36.Nm netstat
37.Nd show network status
38.Sh SYNOPSIS
39.ds address_family Fl f Ar address_family Ns Op , Ns Ar family ...
40.Nm
41.Op Fl Aan
42.Op \*[address_family]
43.Op Fl M Ar core
44.Op Fl N Ar system
45.Nm
46.Op Fl bdghiLlmnqrSsTtv
47.Op \*[address_family]
48.Op Fl M Ar core
49.Op Fl N Ar system
50.Nm
51.Op Fl dn
52.Op Fl I Ar interface
53.Op Fl M Ar core
54.Op Fl N Ar system
55.Op Fl w Ar wait
56.Nm
57.Op Fl M Ar core
58.Op Fl N Ar system
59.Op Fl p Ar protocol
60.Nm
61.Op Fl M Ar core
62.Op Fl N Ar system
63.Op Fl p Ar protocol
64.Fl P Ar pcbaddr
65.Nm
66.Op Fl i
67.Op Fl I Ar Interface
68.Op Fl p Ar protocol
69.Nm
70.Op Fl is
71.Op \*[address_family]
72.Op Fl I Ar Interface
73.Nm
74.Op Fl s
75.Op Fl I Ar Interface
76.Fl B
77.Sh DESCRIPTION
78The
79.Nm
80command symbolically displays the contents of various network-related
81data structures.
82There are a number of output formats,
83depending on the options for the information presented.
84The first form of the command displays a list of active sockets for
85each protocol.
86The second form presents the contents of one of the other network
87data structures according to the option selected.
88Using the third form, with a
89.Ar wait
90interval specified,
91.Nm
92will continuously display the information regarding packet
93traffic on the configured network interfaces.
94The fourth form displays statistics about the named protocol.
95The fifth and sixth forms display per interface statistics for
96the specified protocol or address family.
97.Pp
98The options have the following meaning:
99.Bl -tag -width flag
100.It Fl A
101With the default display,
102show the address of any protocol control blocks associated with sockets; used
103for debugging.
104.It Fl a
105With the default display,
106show the state of all sockets; normally sockets used by
107server processes are not shown.
108.It Fl B
109With the default display,
110show the current
111.Xr bpf 4
112peers.
113To show only the peers listening to a specific interface,
114use the
115.Fl I
116option.
117If the
118.Fl s
119option is present, show the current
120.Xr bpf 4
121statistics.
122.It Fl b
123With the interface display (option
124.Fl i ) ,
125show bytes in and out, instead of packets in and out.
126.It Fl d
127With either interface display (option
128.Fl i
129or an interval, as described below),
130show the number of dropped packets.
131.It \*[address_family]
132Limit statistics or address control block reports to those
133of the specified
134.Ar address_families  .
135The following address families
136are recognized:
137.Ar inet ,
138for
139.Dv AF_INET ;
140.Ar inet6 ,
141for
142.Dv AF_INET6 ;
143.Ar arp ,
144for
145.Dv AF_ARP ;
146.Ar ns ,
147for
148.Dv AF_NS ;
149.Ar atalk ,
150for
151.Dv AF_APPLETALK ;
152.Ar mpls ,
153for
154.Dv AF_MPLS ;
155and
156.Ar local
157or
158.Ar unix ,
159for
160.Dv AF_LOCAL .
161.It Fl g
162Show information related to multicast (group address) routing.
163By default, show the IP Multicast virtual-interface and routing tables.
164If the
165.Fl s
166option is also present, show multicast routing statistics.
167.It Fl h
168When used with
169.Fl b
170in combination with either
171.Fl i
172or
173.Fl I ,
174output "human-readable" byte counts.
175.It Fl I Ar interface
176Show information about the specified interface;
177used with a
178.Ar wait
179interval as described below.
180If the
181.Fl f Ar address_family
182option (with the
183.Fl s
184option) or the
185.Fl p Ar protocol
186option is present, show per-interface statistics on the
187.Ar interface
188for the specified
189.Ar address_family
190or
191.Ar protocol ,
192respectively.
193.It Fl i
194Show the state of interfaces which have been auto-configured
195(interfaces statically configured into a system, but not
196located at boot time are not shown).
197If the
198.Fl a
199options is also present, multicast addresses currently in use are shown
200for each Ethernet interface and for each IP interface address.
201Multicast addresses are shown on separate lines following the interface
202address with which they are associated.
203If the
204.Fl f Ar address_family
205option (with the
206.Fl s
207option) or the
208.Fl p Ar protocol
209option is present, show per-interface statistics on all interfaces
210for the specified
211.Ar address_family
212or
213.Ar protocol ,
214respectively.
215.It Fl L
216Don't show link-level routes (e.g., IPv4 ARP or IPv6 neighbour cache).
217.It Fl l
218With the
219.Fl g
220option, display wider fields for the IPv6 multicast routing table
221.Qq Origin
222and
223.Qq Group
224columns.
225.It Fl M Ar core
226Use
227.Xr kvm 3
228instead of
229.Xr sysctl 3
230to retrieve information and
231extract values associated with the name list from the specified core.
232If the
233.Fl M
234option is not given but the
235.Fl N
236option is given, the default
237.Pa /dev/mem
238is used.
239.It Fl m
240Show statistics recorded by the mbuf memory management routines
241(the network manages a private pool of memory buffers).
242.It Fl N Ar system
243Use
244.Xr kvm 3
245instead of
246.Xr sysctl 3
247to retrieve information and extract the name list from the specified system.
248For the default behavior when only
249.Fl M
250option is given, see the description about when
251.Fa execfile
252is
253.Dv NULL
254in
255.Xr kvm_openfiles 3 .
256.It Fl n
257Show network addresses and ports as numbers (normally
258.Nm
259interprets addresses and ports and attempts to display them
260symbolically).
261This option may be used with any of the display formats.
262.It Fl P Ar pcbaddr
263Dump the contents of the protocol control block (PCB) located at kernel
264virtual address
265.Ar pcbaddr .
266This address may be obtained using the
267.Fl A
268flag.
269The default protocol is TCP, but may be overridden using the
270.Fl p
271flag.
272.It Fl p Ar protocol
273Show statistics about
274.Ar protocol  ,
275which is either a well-known name for a protocol or an alias for it.
276Some protocol names and aliases are listed in the file
277.Pa /etc/protocols .
278A null response typically means that there are no interesting numbers to
279report.
280The program will complain if
281.Ar protocol
282is unknown or if there is no statistics routine for it.
283.It Fl q
284Show software interrupt queue setting/statistics for all protocols.
285.It Fl r
286Show the routing tables.
287When
288.Fl s
289is also present, show routing statistics instead.
290.It Fl S
291Show network addresses as numbers (as with
292.Fl n ,
293but show ports symbolically).
294.It Fl s
295Show per-protocol statistics.
296If this option is repeated, counters with a value of zero are suppressed.
297.It Fl T
298Show MPLS Tags for the routing tables.
299If multiple tags exists, they will
300be comma separated, first tag being the BoS one.
301.It Fl t
302With the
303.Fl i
304option, display the current value of the watchdog timer function.
305.It Fl v
306Show extra (verbose) detail for the routing tables
307.Pq Fl r ,
308or avoid truncation of long addresses.
309.It Fl w Ar wait
310Show network interface statistics at intervals of
311.Ar wait
312seconds.
313.It Fl X
314Force use of
315.Xr sysctl 3
316when retrieving information.
317Some features of
318.Nm
319may not be (fully) supported when using
320.Xr sysctl 3 .
321This flag forces the use of the latter regardless, and emits a message if a
322not yet fully supported feature is used in conjunction with it.
323This flag might be removed at any time; do not rely on its presence.
324.El
325.Pp
326The default display, for active sockets, shows the local
327and remote addresses, send and receive queue sizes (in bytes), protocol,
328and the internal state of the protocol.
329Address formats are of the form ``host.port'' or ``network.port''
330if a socket's address specifies a network but no specific host address.
331When known the host and network addresses are displayed symbolically
332according to the data bases
333.Pa /etc/hosts
334and
335.Pa /etc/networks ,
336respectively.
337If a symbolic name for an address is unknown, or if
338the
339.Fl n
340option is specified, the address is printed numerically, according
341to the address family.
342For more information regarding
343the Internet ``dot format,''
344refer to
345.Xr inet 3 ) .
346Unspecified,
347or ``wildcard'', addresses and ports appear as ``*''.
348You can use the
349.Xr fstat 1
350command to find out which process or processes hold references to a socket.
351.Pp
352The interface display provides a table of cumulative
353statistics regarding packets transferred, errors, and collisions.
354The network addresses of the interface
355and the maximum transmission unit (``mtu'') are also displayed.
356.Pp
357The routing table display indicates the available routes and
358their status.
359Each route consists of a destination host or network
360and a gateway to use in forwarding packets.
361The flags field shows
362a collection of information about the route stored as
363binary choices.
364The individual flags are discussed in more
365detail in the
366.Xr route 8
367and
368.Xr route 4
369manual pages.
370The mapping between letters and flags is:
371.Bl -column XXXX RTF_BLACKHOLE
372.It 1	RTF_PROTO1	Protocol specific routing flag #1
373.It 2	RTF_PROTO2	Protocol specific routing flag #2
374.It B	RTF_BLACKHOLE	Just discard pkts (during updates)
375.It b	RTF_BROADCAST	Route represents a broadcast address
376.It C	RTF_CLONING	Generate new routes on use
377.It c	RTF_CLONED	Cloned routes (generated from RTF_CLONING)
378.It D	RTF_DYNAMIC	Created dynamically (by redirect)
379.It G	RTF_GATEWAY	Destination requires forwarding by intermediary
380.It H	RTF_HOST	Host entry (net otherwise)
381.It L	RTF_LLINFO	Valid protocol to link address translation.
382.It l	RTF_LOCAL	Route represents a local address
383.It M	RTF_MODIFIED	Modified dynamically (by redirect)
384.It p	RTF_ANNOUNCE	Link level proxy
385.It R	RTF_REJECT	Host or net unreachable
386.It S	RTF_STATIC	Manually added
387.It U	RTF_UP	Route usable
388.It X	RTF_XRESOLVE	External daemon translates proto to link address
389.El
390.Pp
391Direct routes are created for each
392interface attached to the local host;
393the gateway field for such entries shows the address of the outgoing interface.
394The refcnt field gives the
395current number of active uses of the route.
396Connection oriented
397protocols normally hold on to a single route for the duration of
398a connection while connectionless protocols obtain a route while sending
399to the same destination.
400The use field provides a count of the number of packets
401sent using that route.
402The mtu entry shows the mtu associated with
403that route.
404This mtu value is used as the basis for the TCP maximum
405segment size.
406The 'L' flag appended to the mtu value indicates that
407the value is locked, and that path mtu discovery is turned off for
408that route.
409A
410.Sq -
411indicates that the mtu for this route has not been set, and a default
412TCP maximum segment size will be used.
413The interface entry indicates
414the network interface used for the route.
415.Pp
416When
417.Nm
418is invoked with the
419.Fl w
420option and a
421.Ar wait
422interval argument, it displays a running count of statistics related to
423network interfaces.
424An obsolescent version of this option used a numeric parameter
425with no option, and is currently supported for backward compatibility.
426This display consists of a column for the primary interface (the first
427interface found during autoconfiguration) and a column summarizing
428information for all interfaces.
429The primary interface may be replaced with another interface with the
430.Fl I
431option.
432The first line of each screen of information contains a summary since the
433system was last rebooted.
434Subsequent lines of output show values
435accumulated over the preceding interval.
436.Pp
437The first character of the flags column in the
438.Fl B
439option shows the status of the
440.Xr bpf 4
441descriptor which has three different values:
442Idle ('I'), Waiting ('W') and Timed Out ('T').
443The second character indicates whether the promisc flag is set.
444The third character indicates the status of the immediate mode.
445The fourth character indicates whether the peer will have the ability
446to see the packets sent.
447And the fifth character shows the header complete flag status.
448.Sh SEE ALSO
449.Xr fstat 1 ,
450.Xr nfsstat 1 ,
451.Xr ps 1 ,
452.Xr sockstat 1 ,
453.Xr vmstat 1 ,
454.Xr inet 3 ,
455.Xr bpf 4 ,
456.Xr hosts 5 ,
457.Xr networks 5 ,
458.Xr protocols 5 ,
459.Xr services 5 ,
460.Xr iostat 8 ,
461.Xr trpt 8
462.Sh HISTORY
463The
464.Nm
465command appeared in
466.Bx 4.2 .
467IPv6 support was added by WIDE/KAME project.
468.\" .Sh FILES
469.\" .Bl -tag -width /dev/mem -compact
470.\" .It Pa /netbsd
471.\" default kernel namelist
472.\" .It Pa /dev/mem
473.\" default memory file
474.\" .El
475.Sh BUGS
476The notion of errors is ill-defined.
477