NAME
netstat
—
show network status
SYNOPSIS
netstat |
[-AaLlnW ] [-f
address_family | -p
protocol] |
netstat |
[-gilns ] [-v ]
[-f address_family]
[-I interface] |
netstat |
-i | -I
interface [-w
wait] [-c
queue] [-abdgqRtS ] |
netstat |
-s [-s ]
[-f address_family |
-p protocol]
[-w wait] |
netstat |
-i | -I
interface -s
[-f address_family |
-p protocol] |
netstat |
-m [-m ] |
netstat |
-r [-Aaln ]
[-f address_family] |
netstat |
-rs [-s ] |
netstat |
-B [-I
interface] |
DESCRIPTION
The netstat
command symbolically displays
the contents of various network-related data structures. There are a number
of output formats, depending on the options for the information presented.
The first form of the command displays a list of active sockets for each
protocol. The second form presents the contents of one of the other network
data structures according to the option selected. Using the third form, with
a wait interval specified,
netstat
will continuously display the information
regarding packet traffic on the configured network interfaces. The fourth
form displays statistics for the specified protocol or address family. If a
wait interval is specified, the protocol information
over the last interval seconds will be displayed. The fifth form displays
per-interface statistics for the specified protocol or address family. The
sixth form displays mbuf(9) statistics. The seventh form displays routing table for the
specified address family. The eighth form displays routing statistics.
The options have the following meaning:
-A
- With the default display, show the address of any protocol control blocks associated with sockets and the flow hash; used for debugging.
-a
- With the default display, show the state of all sockets; normally sockets
used by server processes are not shown. With the routing table display
(option
-r
, as described below), show protocol-cloned routes (routes generated by aRTF_PRCLONING
parent route); normally these routes are not shown. -B
- Show statistics about bpf(4) devices. This includes information like how many packets
have been matched, dropped and received by the
bpf
device, also information about current buffer sizes and device states. The option-I
show information only for thebpf
devices bound the specified interface. -b
- With the interface display (option
-i
, as described below), show the number of bytes in and out. -c
queue- With the queue statistics (option
-q
, as described below), show only those for the specified queue. -d
- With either interface display (option
-i
or an interval, as described below), show the number of dropped packets. -f
address_family- Limit statistics or address control block reports to those of the
specified address family. The following address
families are recognized: inet, for
AF_INET
, inet6, forAF_INET6
, unix, forAF_UNIX
and vsock, forAF_VSOCK
. -g
- Show information related to multicast (group address) membership. If the
-s
option is also present, show extended interface group management statistics. If the-v
option is specified, show link-layer memberships; they are suppressed by default. Source lists for each group will also be printed. Specifiying-v
twice will print the control plane timers for each interface and the source list counters for each group. If the-i
is specified, only that interface will be shown. If the-f
is specified, only information for the address family will be displayed. -I
interface- Show information about the specified interface; used with a
wait interval as described below. If the
-s
option is present, show per-interface protocol statistics on the interface for the specified address_family or protocol, or for all protocol families. -i
- Show the state of interfaces which have been auto-configured (interfaces
statically configured into a system, but not located at boot time are not
shown). If the
-a
options is also present, multicast addresses currently in use are shown for each Ethernet interface and for each IP interface address. Multicast addresses are shown on separate lines following the interface address with which they are associated. If the-s
option is present, show per-interface statistics on all interfaces for the specified address_family or protocol, or for all protocol families. -L
- Show the size of the various listen queues. The first count shows the number of unaccepted connections. The second count shows the amount of unaccepted incomplete connections. The third count is the maximum number of queued connections.
-l
- Print full IPv6 address.
-m
- Show statistics recorded by the memory management routines (the network
stack manages a private pool of memory buffers). More detailed information
about the buffers, which includes their cache related statistics, can be
obtained by using
-mm
or-m
-m
option. -n
- Show network addresses as numbers (normally
netstat
interprets addresses and attempts to display them symbolically). This option may be used with any of the display formats. -p
protocol- Show statistics about protocol, which is either a well-known name for a protocol or an alias for it. Some protocol names and aliases are listed in the file /etc/protocols. The special protocol name “bdg” is used to show bridging statistics. A null response typically means that there are no interesting numbers to report. The program will complain if protocol is unknown or if there is no statistics routine for it.
-q
- Show network interface send queue statistics. By default all queues are
displayed, unless specified with
-c
. This option requires specifying an interface with-I
option. More detailed information about the queues, which includes their queueing algorithm related statistics, can be obtained by using-qq
or-q
-q
option. -r
- Show the routing tables. Use with
-a
to show protocol-cloned routes. When-s
is also present, show routing statistics instead. When-l
is also present,netstat
assumes more columns are there and the maximum transmission unit. More detailed information about the route metrics are displayed with-ll
for TCP round trip times-lll
for all metrics. Use the-z
flags to display only entries with non-zero RTT values. (“mtu”) are also displayed. -R
- Show reachability information. Use with
-i
to show link-layer reachability information for a given interface. -s
- Show per-protocol statistics. If this option is repeated, counters with a value of zero are suppressed. For security reasons, root privileges are required to read TCP statistics and in the absence of such privileges all TCP counters will be reported as zero.
-S
- Show interface link status and interface state information about the
specified interface. This option requires specifying an interface with
-I
option. -v
- Increase verbosity level.
-W
- In certain displays, avoid truncating addresses even if this causes some fields to overflow.
-w
wait- Show network interface or protocol statistics at intervals of wait seconds.
-x
- Show extended link-layer reachability information in addition to that
shown by the
-R
flag.
OUTPUT
The default display, for active sockets, shows the local and
remote addresses, send and receive queue sizes (in bytes), protocol, and the
internal state of the protocol. Address formats are of the form
“host.port” or “network.port” if a socket's
address specifies a network but no specific host address. If known, the host
and network addresses are displayed symbolically according to the databases
/etc/hosts and
/etc/networks, respectively. If a symbolic name for
an address is unknown, or if the -n
option is
specified, the address is printed numerically, according to the address
family. For more information regarding the Internet “dot
format”, refer to inet(3)). Unspecified, or “wildcard”, addresses
and ports appear as “*”.
Internet domain socket states:
CLOSED: The socket is not in use. |
Pp |
LISTEN: The socket is listening for incoming connections. Unconnected |
listening sockets like these are only displayed when using the -a option. |
Pp |
SYN_SENT: The socket is actively trying to establish a connection to a |
remote peer. |
Pp |
SYN_RCVD: The socket has passively received a connection request from a |
remote peer. |
Pp |
ESTABLISHED: The socket has an established connection between a local |
application and a remote peer. |
Pp |
CLOSE_WAIT: The socket connection has been closed by the remote peer, |
and the system is waiting for the local application to close its half of |
the connection. |
Pp |
LAST_ACK: The socket connection has been closed by the remote peer, the |
local application has closed its half of the connection, and the system |
is waiting for the remote peer to acknowledge the close. |
Pp |
FIN_WAIT_1: The socket connection has been closed by the local |
application, the remote peer has not yet acknowledged the close, and the |
system is waiting for it to close its half of the connection. |
Pp |
FIN_WAIT_2: The socket connection has been closed by the local |
application, the remote peer has acknowledged the close, and the system |
is waiting for it to close its half of the connection. |
Pp |
CLOSING: The socket connection has been closed by the local application |
and the remote peer simultaneously, and the remote peer has not yet |
acknowledged the close attempt of the local application. |
Pp |
TIME_WAIT: The socket connection has been closed by the local |
application, the remote peer has closed its half of the connection, and |
the system is waiting to be sure that the remote peer received the last |
acknowledgement. |
The interface display provides a table of cumulative statistics regarding packets transferred, errors, and collisions. The network addresses of the interface and the maximum transmission unit (“mtu”) are also displayed.
The routing table display indicates the available routes and their status. Each route consists of a destination host or network and a gateway to use in forwarding packets. The flags field shows a collection of information about the route stored as binary choices. The individual flags are discussed in more detail in the route(8) and route(4) manual pages. The mapping between letters and flags is:
1 | RTF_PROTO1 | Protocol specific routing flag #1 | |
2 | RTF_PROTO2 | Protocol specific routing flag #2 | |
3 | RTF_PROTO3 | Protocol specific routing flag #3 | |
B | RTF_BLACKHOLE | Just discard packets (during updates) | |
b | RTF_BROADCAST | The route represents a broadcast address | |
C | RTF_CLONING | Generate new routes on use | |
c | RTF_PRCLONING | Protocol-specified generate new routes on use | |
D | RTF_DYNAMIC | Created dynamically (by redirect) | |
G | RTF_GATEWAY | Destination requires forwarding by intermediary | |
H | RTF_HOST | Host entry (net otherwise) | |
I | RTF_IFSCOPE | Route is associated with an interface scope | |
i | RTF_IFREF | Route is holding a reference to the interface | |
L | RTF_LLINFO | Valid protocol to link address translation | |
M | RTF_MODIFIED | Modified dynamically (by redirect) | |
m | RTF_MULTICAST | The route represents a multicast address | |
R | RTF_REJECT | Host or net unreachable | |
r | RTF_ROUTER | Host is a default router | |
S | RTF_STATIC | Manually added | |
U | RTF_UP | Route usable | |
W | RTF_WASCLONED | Route was generated as a result of cloning | |
X | RTF_XRESOLVE | External daemon translates proto to link address | |
Y | RTF_PROXY | Proxying; cloned routes will not be scoped | |
g | RTF_GLOBAL | Route to a destination of the global internet (policy hint) |
Direct routes are created for each interface attached to the local host; the gateway field for such entries shows the address of the outgoing interface. The refcnt field gives the current number of active uses of the route. Connection oriented protocols normally hold on to a single route for the duration of a connection while connectionless protocols obtain a route while sending to the same destination. The use field provides a count of the number of packets sent using that route. The interface entry indicates the network interface utilized for the route. A route which is marked with the RTF_IFSCOPE flag is instantiated for the corresponding interface. A cloning route which is marked with the RTF_PROXY flag will not generate new routes that are associated with its interface scope.
When netstat
is invoked with the
-w
option and a wait interval
argument, it displays a running count of statistics related to network
interfaces or protocols. An obsolete version of this option used a numeric
parameter with no option, and is currently supported for backward
compatibility. By default, this display summarizes information for all
interfaces. Information for a specific interface may be displayed with the
-I
option.
SEE ALSO
nfsstat(1), ps(1), inet(4), unix(4), hosts(5), networks(5), protocols(5), route(8), services(5), iostat(8), bpf(4),
HISTORY
The netstat
command appeared in
4.2BSD.
IPv6 support was added by WIDE/KAME project.
BUGS
The notion of errors is ill-defined.