Merge branch 'vendor/LESS'
[dragonfly.git] / usr.bin / netstat / netstat.1
1 .\" Copyright (c) 1983, 1990, 1992, 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 .\"     @(#)netstat.1   8.8 (Berkeley) 4/18/94
29 .\" $FreeBSD: src/usr.bin/netstat/netstat.1,v 1.22.2.13 2003/05/03 22:10:02 keramida Exp $
30 .\"
31 .Dd July 12, 2008
32 .Dt NETSTAT 1
33 .Os
34 .Sh NAME
35 .Nm netstat
36 .Nd show network status
37 .Sh DESCRIPTION
38 The
39 .Nm
40 command symbolically displays the contents of various network-related
41 data structures.
42 There are a number of output formats,
43 depending on the options for the information presented.
44 .Bl -tag -width indent
45 .It Xo
46 .Bk -words
47 .Nm
48 .Op Fl AaLlnPSW
49 .Op Fl c Ar cpu
50 .Op Fl f Ar protocol_family | Fl p Ar protocol
51 .Op Fl M Ar core
52 .Op Fl N Ar system
53 .Ek
54 .Xc
55 Display a list of active sockets
56 (protocol control blocks)
57 for each network protocol,
58 for a particular
59 .Ar protocol_family ,
60 or for a single
61 .Ar protocol .
62 If
63 .Fl A
64 is also present,
65 show the address of a protocol control block (PCB)
66 associated with a socket; used for debugging.
67 If
68 .Fl a
69 is also present,
70 show the state of all sockets;
71 normally sockets used by server processes are not shown.
72 If
73 .Fl L
74 is also present,
75 show the size of the various listen queues.
76 The first count shows the number of unaccepted connections,
77 the second count shows the amount of unaccepted incomplete connections,
78 and the third count is the maximum number of queued connections.
79 If
80 .Fl S
81 is also present,
82 show network addresses as numbers (as with
83 .Fl n )
84 but show ports symbolically.
85 .It Xo
86 .Bk -words
87 .Nm
88 .Fl i | I Ar interface
89 .Op Fl aBbdnt
90 .Op Fl f Ar address_family
91 .Op Fl M Ar core
92 .Op Fl N Ar system
93 .Ek
94 .Xc
95 Show the state of all network interfaces or a single
96 .Ar interface
97 which have been auto-configured
98 (interfaces statically configured into a system, but not
99 located at boot time are not shown).
100 An asterisk
101 .Pq Dq Li *
102 after an interface name indicates that the interface is
103 .Dq down .
104 If
105 .Fl a
106 is also present, multicast addresses currently in use are shown
107 for each Ethernet interface and for each IP interface address.
108 Multicast addresses are shown on separate lines following the interface
109 address with which they are associated.
110 If
111 .Fl b
112 is also present, show the number of bytes in and out.
113 If
114 .Fl d
115 is also present, show the number of dropped packets.
116 If
117 .Fl t
118 is also present, show the contents of watchdog timers.
119 If
120 .Fl B
121 is also present, the maximum buffer sizes are displayed instead
122 of current buffer usage.
123 .It Xo
124 .Bk -words
125 .Nm
126 .Fl w Ar wait
127 .Op Fl I Ar interface
128 .Op Fl d
129 .Op Fl M Ar core
130 .Op Fl N Ar system
131 .Ek
132 .Xc
133 At intervals of
134 .Ar wait
135 seconds,
136 display the information regarding packet
137 traffic on all configured network interfaces
138 or a single
139 .Ar interface .
140 If
141 .Fl d
142 is also present, show the number of dropped packets.
143 .It Xo
144 .Bk -words
145 .Nm
146 .Fl s Op Fl s
147 .Op Fl z
148 .Op Fl f Ar protocol_family | Fl p Ar protocol
149 .Op Fl M Ar core
150 .Op Fl N Ar system
151 .Ek
152 .Xc
153 Display system-wide statistics for each network protocol,
154 for a particular
155 .Ar protocol_family ,
156 or for a single
157 .Ar protocol .
158 If
159 .Fl s
160 is repeated, counters with a value of zero are suppressed.
161 If
162 .Fl z
163 is also present, reset statistic counters after displaying them.
164 .It Xo
165 .Bk -words
166 .Nm
167 .Fl i | I Ar interface Fl s
168 .Op Fl f Ar protocol_family | Fl p Ar protocol
169 .Op Fl M Ar core
170 .Op Fl N Ar system
171 .Ek
172 .Xc
173 Display per-interface statistics for each network protocol,
174 for a particular
175 .Ar protocol_family ,
176 or for a single
177 .Ar protocol .
178 .It Xo
179 .Bk -words
180 .Nm
181 .Fl m
182 .Op Fl M Ar core
183 .Op Fl N Ar system
184 .Ek
185 .Xc
186 Show statistics recorded by the memory management routines
187 .Pq Xr mbuf 9 .
188 The network manages a private pool of memory buffers.
189 .It Xo
190 .Bk -words
191 .Nm
192 .Fl r
193 .Op Fl AalnW
194 .Op Fl f Ar address_family
195 .Op Fl M Ar core
196 .Op Fl N Ar system
197 .Ek
198 .Xc
199 Display the contents of all routing tables,
200 or a routing table for a particular
201 .Ar address_family .
202 If
203 .Fl A
204 is also present,
205 show the contents of the internal Patricia tree
206 structures; used for debugging.
207 If
208 .Fl a
209 is also present,
210 show protocol-cloned routes
211 (routes generated by an
212 .Dv RTF_PRCLONING
213 parent route);
214 normally these routes are not shown.
215 When
216 .Fl W
217 or
218 .Fl l
219 is also present,
220 show the path MTU
221 and MPLS label operations
222 for each route.
223 .It Xo
224 .Bk -words
225 .Nm
226 .Fl rs
227 .Op Fl s
228 .Op Fl M Ar core
229 .Op Fl N Ar system
230 .Ek
231 .Xc
232 Display routing statistics.
233 If
234 .Fl s
235 is repeated, counters with a value of zero are suppressed.
236 .It Xo
237 .Bk -words
238 .Nm
239 .Fl g
240 .Op Fl lW
241 .Op Fl f Ar address_family
242 .Op Fl M Ar core
243 .Op Fl N Ar system
244 .Ek
245 .Xc
246 Show information related to multicast (group address) routing.
247 By default, show the IP Multicast virtual-interface and routing tables.
248 .It Xo
249 .Bk -words
250 .Nm
251 .Fl gs
252 .Op Fl s
253 .Op Fl f Ar address_family
254 .Op Fl M Ar core
255 .Op Fl N Ar system
256 .Ek
257 .Xc
258 Show multicast routing statistics.
259 If
260 .Fl s
261 is repeated, counters with a value of zero are suppressed.
262 .El
263 .Pp
264 Some options have the general meaning:
265 .Bl -tag -width flag
266 .It Fl c Ar cpu
267 On SMP systems the route table is replicated.  This option allows
268 the route table for a specific cpu to be accessed and exists
269 primarily for debugging purposes.
270 .It Fl f Ar address_family , Fl f Ar protocol_family , Fl p Ar protocol
271 Limit display to those records
272 of the specified
273 .Ar address_family ,
274 .Ar protocol_family
275 or a single
276 .Ar protocol .
277 The following address families, protocol families and protocols are recognized:
278 .Pp
279 .Bl -tag -width ".Cm netgraph , ng Pq Dv AF_NETGRAPH" -compact
280 .It Em Family
281 .Em Protocols
282 .It Cm inet Pq Dv AF_INET PF_INET
283 .Cm carp , divert , icmp , igmp , ip , ipsec , pim , tcp , udp
284 .It Cm inet6 Pq Dv AF_INET6 PF_INET6
285 .Cm carp , icmp6 , ip6 , ipsec6 , rip6 , tcp , udp
286 .It Cm pfkey Pq Dv AF_KEY PF_KEY
287 .Cm pfkey
288 .It Cm netgraph , ng Pq Dv AF_NETGRAPH PF_NETGRAPH
289 .Cm ctrl , data
290 .It Cm ipx Pq Dv AF_IPX PF_IPX
291 .Cm ipx , spx
292 .\".It Cm ns Pq Dv AF_NS PF_NS
293 .\".Cm idp , ns_err , spp
294 .\".It Cm iso Pq Dv AF_ISO PF_ISO
295 .\".Cm clnp , cltp , esis , tp
296 .It Cm unix Pq Dv AF_UNIX PF_UNIX
297 .It Cm link Pq Dv AF_LINK PF_LINK
298 .It Cm mpls Pq Dv AF_MPLS PF_MPLS
299 .El
300 .Pp
301 The program will complain if
302 .Ar protocol
303 is unknown or if there is no statistics routine for it.
304 .It Fl l
305 The
306 .Fl l
307 option is equivalent to
308 .Fl W .
309 .It Fl M
310 Extract values associated with the name list from the specified core
311 instead of the default
312 .Pa /dev/kmem .
313 .It Fl N
314 Extract the name list from the specified system instead of the default,
315 which is the kernel image the system has booted from.
316 .It Fl n
317 Show network addresses and ports as numbers.
318 Normally
319 .Nm
320 attempts to resolve addresses and ports,
321 and display them symbolically.
322 .It Fl P
323 Display additional protocol-specific information.  For TCP the current
324 transmit window, unacked sequence space, and RTT is displayed.
325 .It Fl W
326 Wide display.
327 In certain displays, add columns and avoid truncating
328 addresses even if this causes some fields to overflow.
329 .El
330 .Pp
331 The default display, for active sockets, shows the local
332 and remote addresses, send and receive queue sizes (in bytes), protocol,
333 and the internal state of the protocol.
334 Address formats are of the form
335 .Dq host.port
336 or
337 .Dq network.port
338 if a socket's address specifies a network but no specific host address.
339 When known, the host and network addresses are displayed symbolically
340 according to the databases
341 .Xr hosts 5
342 and
343 .Xr networks 5 ,
344 respectively.
345 If a symbolic name for an address is unknown, or if
346 the
347 .Fl n
348 option is specified, the address is printed numerically, according
349 to the address family.
350 For more information regarding
351 the Internet IPv4
352 .Dq dot format ,
353 refer to
354 .Xr inet 3 .
355 Unspecified,
356 or
357 .Dq wildcard ,
358 addresses and ports appear as
359 .Dq Li * .
360 .Pp
361 The interface display provides a table of cumulative
362 statistics regarding packets transferred, errors, and collisions.
363 The network addresses of the interface
364 and the maximum transmission unit
365 .Pq Dq mtu
366 are also displayed.
367 .Pp
368 The routing table display indicates the available routes and their status.
369 Each route consists of a destination host or network, and a gateway to use
370 in forwarding packets.
371 The flags field shows a collection of information about the route stored
372 as binary choices.
373 The individual flags are discussed in more detail in the
374 .Xr route 8
375 and
376 .Xr route 4
377 manual pages.
378 The mapping between letters and flags is:
379 .Bl -column ".Li W" ".Dv RTF_WASCLONED"
380 .It Li 1 Ta Dv RTF_PROTO1 Ta "Protocol specific routing flag #1"
381 .It Li 2 Ta Dv RTF_PROTO2 Ta "Protocol specific routing flag #2"
382 .It Li 3 Ta Dv RTF_PROTO3 Ta "Protocol specific routing flag #3"
383 .It Li B Ta Dv RTF_BLACKHOLE Ta "Just discard pkts (during updates)"
384 .It Li b Ta Dv RTF_BROADCAST Ta "The route represents a broadcast address"
385 .It Li C Ta Dv RTF_CLONING Ta "Generate new routes on use"
386 .It Li c Ta Dv RTF_PRCLONING Ta "Protocol-specified generate new routes on use"
387 .It Li D Ta Dv RTF_DYNAMIC Ta "Created dynamically (by redirect)"
388 .It Li G Ta Dv RTF_GATEWAY Ta "Destination requires forwarding by intermediary"
389 .It Li H Ta Dv RTF_HOST Ta "Host entry (net otherwise)"
390 .It Li L Ta Dv RTF_LLINFO Ta "Valid protocol to link address translation"
391 .It Li M Ta Dv RTF_MODIFIED Ta "Modified dynamically (by redirect)"
392 .It Li m Ta Dv RTF_MPLSOPS Ta "MPLS label operations"
393 .It Li R Ta Dv RTF_REJECT Ta "Host or net unreachable"
394 .It Li S Ta Dv RTF_STATIC Ta "Manually added"
395 .It Li U Ta Dv RTF_UP Ta "Route usable"
396 .It Li W Ta Dv RTF_WASCLONED Ta "Route was generated as a result of cloning"
397 .It Li X Ta Dv RTF_XRESOLVE Ta "External daemon translates proto to link address"
398 .El
399 .Pp
400 Direct routes are created for each
401 interface attached to the local host;
402 the gateway field for such entries shows the address of the outgoing interface.
403 The refcnt field gives the
404 current number of active uses of the route.
405 Connection oriented
406 protocols normally hold on to a single route for the duration of
407 a connection while connectionless protocols obtain a route while sending
408 to the same destination.
409 The use field provides a count of the number of packets
410 sent using that route.
411 The interface entry indicates the network interface utilized for the route.
412 .Pp
413 When
414 .Nm
415 is invoked with the
416 .Fl w
417 option and a
418 .Ar wait
419 interval argument, it displays a running count of statistics related to
420 network interfaces.
421 An obsolescent version of this option used a numeric parameter
422 with no option, and is currently supported for backward compatibility.
423 By default, this display summarizes information for all interfaces.
424 Information for a specific interface may be displayed with the
425 .Fl I
426 option.
427 .Sh SEE ALSO
428 .Xr fstat 1 ,
429 .Xr nfsstat 1 ,
430 .Xr ps 1 ,
431 .Xr sockstat 1 ,
432 .Xr carp 4 ,
433 .Xr inet 4 ,
434 .Xr inet6 4 ,
435 .Xr route 4 ,
436 .Xr unix 4 ,
437 .Xr hosts 5 ,
438 .Xr networks 5 ,
439 .Xr protocols 5 ,
440 .Xr services 5 ,
441 .Xr iostat 8 ,
442 .Xr route 8 ,
443 .Xr trpt 8 ,
444 .Xr vmstat 8 ,
445 .Xr mbuf 9
446 .Sh HISTORY
447 The
448 .Nm
449 command appeared in
450 .Bx 4.2 .
451 .Pp
452 IPv6 support was added by WIDE/KAME project.
453 .Sh BUGS
454 The notion of errors is ill-defined.