This articleneeds additional citations forverification. Please helpimprove this article byadding citations to reliable sources. Unsourced material may be challenged and removed. Find sources: "Netstat" – news ·newspapers ·books ·scholar ·JSTOR(August 2012) (Learn how and when to remove this message) |
![]() The netstat command in Linux | |
Developer(s) | Variousopen-source andcommercial developers |
---|---|
Initial release | 1983; 42 years ago (1983) |
Written in | Plan 9:C |
Operating system | Unix,Unix-like,Plan 9,Inferno,OS/2,Microsoft Windows,ReactOS |
Platform | Cross-platform |
Type | Command |
License | OS/2, Windows:Proprietarycommercial software net-tools, ReactOS:GPLv2 Plan 9:MIT License |
Incomputing,netstat
is acommand-linenetwork utility that displays open network sockets,routing tables, and a number of network interface (network interface controller orsoftware-defined network interface) and network protocol statistics. It is available onUnix,Plan 9,Inferno, andUnix-likeoperating systems includingmacOS,Linux,Solaris andBSD. It is also available onIBMOS/2 and onMicrosoftWindows NT-based operating systems includingWindows XP,Windows Vista,Windows 7,Windows 8 andWindows 10.
It is used for finding problems in the network and to determine the amount of traffic on the network as a performance measurement.[1] On Linux this program is mostly obsolete, although still included in many distributions.
On Linux,netstat
(part of "net-tools") is superseded byss
(part ofiproute2). The replacement fornetstat -r
isip route
, the replacement fornetstat -i
isip -s link
, and the replacement fornetstat -g
isip maddr
, all of which are recommended instead.[2][3][4][5]
Netstat provides statistics for the following:
-n
parameter is specified. An asterisk (*) is shown for the host if the server is listening on all interfaces. If the port is not yet established, the port number is shown as an asterisk.-n
parameter is specified. If the port is not yet established, the port number is shown as an asterisk (*).Parameters used with this command must be prefixed with a hyphen (-) rather than a slash (/). Some parameters are not supported on all platforms.
Name | Description | Windows | ReactOS | macOS | BSD | NetBSD | FreeBSD | Linux | Solaris | OS/2 |
---|---|---|---|---|---|---|---|---|---|---|
-a | Displaysall active connections and the TCP and UDPports on which the computer is listening. | Yes | Yes | Yes | Yes | Yes | Yes | |||
-b | Displays thebinary (executable) program's name involved in creating each connection or listening port. (Windows XP,Windows Server 2003 and newer Windows operating systems; not MicrosoftWindows 2000 or older). | Yes | No | No | ||||||
-b | Causes-i to report the total number ofbytes of traffic. | No | Yes | Yes | No | |||||
-e | Displaysethernet statistics, such as the number ofbytes and packets sent and received. This parameter can be combined with-s. | Yes | Yes | No | ||||||
-f | Displaysfully qualified domain names <FQDN> for foreign addresses (only available onWindows Vista and newer operating systems). | Yes | No | No | ||||||
-fAddress Family | Limits display to a particular socket address family,unix,inet,inet6 | No | Yes | No | ||||||
-g | Displays multicastgroup membership information for both IPv4 and IPv6 (may only be available on newer operating systems) | No | No | Yes | ||||||
-i | Displays networkinterfaces and their statistics | No | No | Yes | Yes | Yes | Yes | Yes | ||
-m | Displays thememory statistics for the networking code (STREAMS statistics on Solaris). | No | No | Yes | Yes | Yes | Yes | Yes | ||
-n | Displays active TCP connections, however, addresses and port numbers are expressed numerically and no attempt is made to determine names. | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | |
-o | Displays active TCP connections and includes the process id (PID) for each connection. You can find the application based on the PID in theProcesses tab inWindows Task Manager. This parameter can be combined with-a, -n, and-p. This parameter is available on MicrosoftWindows XP,Windows Server 2003, andWindows 2000 if a hotfix is applied.[6] | Yes | No | No | ||||||
-pprotocol | Shows connections for theprotocol specified byprotocol. In this case,protocol can betcp, udp, tcpv6, or udpv6. If this parameter is used with-s to display statistics by protocol,protocol can betcp, udp, icmp, ip, tcpv6, udpv6, icmpv6, oripv6. | Yes | Yes | Yes | Yes | Yes | Yes | |||
-p | Show whichprocesses are using which sockets (similar to -b under Windows) (you must be root to do this) | No | No | Yes | ||||||
-Pprotocol | Shows connections for theprotocol specified byprotocol. In this case,protocol can beip, ipv6, icmp, icmpv6, igmp, udp, tcp, or rawip. | No | No | Yes | ||||||
-r | Displays the contents of theIProuting table. (This is equivalent to theroute print command under Windows.) | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes |
-s | Displaysstatistics by protocol. By default, statistics are shown for theTCP,UDP,ICMP, andIP protocols. If the IPv6 protocol for Windows XP is installed, statistics are shown for the TCP overIPv6, UDP over IPv6,ICMPv6, and IPv6 protocols. The-p parameter can be used to specify a set of protocols. | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | |
-t | Display only TCP connections. | No | Yes | Yes | ||||||
-u | Display only UDP connections. | No | No | Yes | Yes | |||||
-W | Display wide output - doesn't truncate hostnames or IPv6 addresses | No | No | Yes | No | |||||
-x | Displays NetworkDirect connections, listeners, and shared endpoints. | Yes | ||||||||
-y | Displays the TCP connection template for all connections.Cannot be combined with the other options. | Yes | ||||||||
-v | When used in conjunction with-b it will display the sequence of components involved in creating the connection or listening port for all executables. | Yes | No | No | ||||||
Interval | Redisplays the selected information every Interval seconds. Press CTRL+C to stop the redisplay. If this parameter is omitted, netstat prints the selected information only once. | Yes | Yes | No | ||||||
-h | Displays help at the command prompt. | Yes | No | Yes | Yes | Yes | Yes | Yes | Yes | No |
-? | Displays help at the command prompt. | Yes | No | No | No | No | No | No | No | Yes |
/? | Displays help at the command prompt. | Yes | Yes | No | No | No | No | No | No | No |
On macOS, BSD systems, Linux distributions, and Microsoft Windows:
To display thestatistics for only the TCP or UDPprotocols, type one of the following commands:
netstat -sp tcp
netstat -sp udp
On Unix-like systems:
To display all ports open by a process with idpid:
netstat -aop | grep "pid"
To continuously display open TCP and UDP connections numerically and also which program is using them on Linux:
netstat -nutpacw
On Microsoft Windows:
To display active TCP connections and the process IDs every5 seconds, type the following command (works on NT based systems only, or Windows 2000 with hotfix):
netstat -o 5
To display active TCP connections and the process IDs usingnumerical form, type the following command (works on NT based systems only, or Windows 2000 with hotfix):
netstat -no
Command | Explanation |
---|---|
netstat -a | Shows all sockets, both listening and non-listening, all protocols like TCP, UDP etc. |
netstat -at | Shows only TCP connections (-au shows only UDP connections) |
netstat -ant | Shows all TCP connections with no DNS resolution (show IP addresses instead). |
netstat -al | Shows only listening sockets. |
netstat -aep | Also show PID and to which program each socket belongs, e adds extra info like the user. Run as root to see all PIDs. |
netstat -s | Shows network statistics. |
netstat -r | Shows kernel routing information. This is the same output as route -e. |
netstat -i | Displays a table of all network interfaces. Add -e to get output similar to ifconfig. |
netstat -ct | Displays TCP connections continuously. |
netstat -g | Display multicast group membership information for IPv4 and IPv6. |
netstat -lntu | Display all services listening for TCP and UDP, all free open ports on the local machine. |
netstat -atnp | grep ESTA | Displays all currently "established" TCP connections. |
Netstat uses an asterisk * as a wildcard which means "any". An example would be
Example output:
....Local Address Foreign Address State... *:smtp *:* LISTEN
Under "Local Address" *, in*:smtp
, means the process is listening on all of the network interfaces the machine has for the port mapped as smtp (see /etc/services for service resolution). This can also be shown as 0.0.0.0.The first *, in*:*
, means connections can come from any IP address, and the second *, in*:*
, means the connection can originate from any port on the remote machine.
Some versions ofnetstat
lack explicit field delimiters in their printf-generated output, leading to numeric fields running together and thus corrupting the output data.
netstat
commandnetstat
commandUnderLinux, raw data can often be obtained from the/proc/net/dev to work around theprintf output corruption arising in netstat's network interface statistics summary,netstat -i
, until such time as the problem is corrected.[citation needed]
On theWindows platform, netstat information can be retrieved by calling theGetTcpTable andGetUdpTable functions in the IP HelperAPI, or IPHLPAPI.DLL. Information returned includes local and remoteIP addresses, local and remote ports, and (for GetTcpTable)TCP status codes. In addition to the command-line netstat.exe tool that ships with Windows,GUI-based netstat programs are available.
On the Windows platform, this command is available only if theInternet Protocol (TCP/IP) protocol is installed as a component in the properties of a network adapter in Network Connections.
On theWindows platform running Remote Desktop Services (formerly Terminal Services) it will only show connections for the current user, not for the whole computer.
OnmacOS, the /System/Library/CoreServices/Applications folder (or /Applications/Utilities inOS X Mountain Lion and earlier) contains a network GUI utility calledNetwork Utility, theNetstat tab of which runs the netstat command and displays its output in the tab.
This program is obsolete. Replacement for netstat is ss. Replacement for netstat -r is ip route. Replacement for netstat -i is ip -s link. Replacement for netstat -g is ip maddr.
netstat(8)
– Linux Programmer'sManual – Administration and Privileged Commandsnetstat(1)
– FreeBSD General CommandsManualnetstat(8)
– Solaris 11.4 System Administration Commands ReferenceManualnetstat(1)
– Inferno General commandsManual