ss command in Linux with examples
This article is a follow-up to the previous 90 Linux Commands frequently used by Linux Sysadmins post. Every week, as time allows, I will publish articles on the 90 commands geared toward Linux sysadmins and Linux power users.
What is the ss
command?
The ss
command is a powerful utility used to display detailed information about network sockets and connections on a Linux system. It is a modern replacement for the older netstat
command and offers more advanced features and flexibility. In this blog post, we will explore the ss
command in detail and provide some examples of how to use it.
The ss
command stands for “socket statistics” and is a utility that provides detailed information about network sockets and connections. It is typically used to diagnose and troubleshoot network issues, such as identifying open ports, viewing established connections, and monitoring network traffic.
Unlike the older netstat
command, which is limited to displaying only basic information about network sockets, the ss
command provides a wide range of options and filtering capabilities that allow you to customize the output to your needs.
Feature | netstat | ss |
---|---|---|
Speed | Slower | Faster |
Output Details | Limited | Comprehensive |
Deprecated? | Yes | No |
ss
command examples
Here are some examples of how to use the ss
command:
To show all listening TCP connections, use the following:
ss -tln
– This command will show all listening TCP connections on the system, along with the corresponding port number and the process ID that is listening on that port.
To show all established TCP connections, use the following:
ss -tan
– This command will show all established TCP connections on the system, including the local and remote IP addresses, the corresponding port numbers, and the state of the connection.
To show all UDP sockets, use the following:
ss -uln
– This command will show all open UDP sockets on the system, along with the corresponding port number and the process ID that is using that socket.
To show all UNIX sockets, use the following:
ss -x
– This command will show all UNIX sockets on the system, including the type of socket, the inode number, and the process ID that is using that socket.
To show all TCP sockets in the state of TIME-WAIT, use the following:
ss -tan state time-wait
– This command will show all TCP sockets in the state of TIME-WAIT, which is a state that a connection enters after it has been closed. This can be useful for diagnosing connection-related issues.
To show all processes that are using internet sockets, use the following:
ss -ap
– This command will show all processes that are using internet sockets on the system, along with the corresponding socket information and the process ID.
Related commands:
netstat
– This is the older utility thatss
replaces. It displays basic information about network sockets and connections.lsof
– This command lists open files, including network sockets.tcpdump
– This command captures network traffic and displays it in real-time, making it useful for network troubleshooting.nmap
– This command is a network scanner that can be used to identify open ports, services, and operating systems on a remote system.ip
– This is a command-line utility for managing network interfaces and routing tables on a Linux system. It can be used to configure network settings, such as IP addresses and routing rules.
Useful reading:
- Linux commands: Drop these old utilities for modern alternatives.
- Linuxfoundation – iproute2.
- https://tldp.org/HOWTO/Adv-Routing-HOWTO/lartc.iproute2.html
Conclusion
The ss
command is a cool modern utility that is faster and more powerful than netstat. By learning its features and filters, you can troubleshoot and optimize network stuff better. Whether you’re checking open ports, monitoring traffic or resolving connection states, the ss command is a must-have in your Linux toolbox.
EXCELLENT! How about 90 ss examples! These examples are awesome. Thanks!
Thanks for the feedback. More to come. That’s encouraging to hear.
@unixrab Here are some additional
ss
command examples that are not already listed in the article:This command will display all TCP sockets that are in the SYN-RECV state. This state is typically associated with incoming connections that are in the process of being established.
This command will show detailed information about the TCP sockets that are listening on port 80. You can replace
:80
with the specific port you want to investigate.This command will list all TCP sockets using both IPv4 and IPv6 address families. You can use
-t4
for IPv4 only or-t6
for IPv6 only.This command will show both listening and non-listening UDP sockets on the system. It provides a comprehensive view of UDP sockets.
Edit: article updated.