Signup/Sign In

How to use SS command in Linux

The ss command is a powerful tool for troubleshooting and analyzing network connections in a Linux system. It is a successor to the netstat command, which has been deprecated in many modern Linux distributions. ss provides more information and has more options than netstat, making it a useful tool for network administrators and system administrators.

ss command syntax:

$ ss [options] [ FILTER ]

ss command options:

-h, --help Show summary of options.
-V, --version Output version information
-H, --no-header Suppress header line.
-O, --oneline Print each socket's data on a single line.
-n, --numeric Do not try to resolve service names. Show exact bandwidth values, instead of human-readable.
-r, --resolve Try to resolve numeric address/ports.
-a, --all Display both listening and non-listening (for TCP this means established connections) sockets.
-l, --listening Display only listening sockets (these are omitted by default).
-o, --options Show timer information.
-e, --extended Show detailed socket information.
-m, --memory Show socket memory usage.
-p, --processes Show process using socket.
-i, --info Show internal TCP information.
--tos Show Type of Service (ToS) and priority information.
--cgroup Show cgroup information.
-K, --kill Attempts to forcibly close sockets. This option displays sockets that are successfully closed and silently skips sockets that the kernel does not support closing. It supports IPv4 and IPv6 sockets only.
-s, --summary Print summary statistics. This option does not parse socket lists obtaining summary from various sources. It is useful when amount of sockets is so huge that parsing /proc/net/tcp is painful.
-E, --events Continually display sockets as they are destroyed. As the -p option but also shows process security context.
-Z, --context As the -Z option but also shows the socket context.
-N NSNAME, --net=NSNAME Switch to the specified network namespace name.
-b, --bpf Show socket BPF filters (only administrator/root user are allowed to get these information).
-4, --ipv4 Display only IP version 4 sockets (alias for -f inet).
-6, --ipv6 Display only IP version 6 sockets (alias for -f inet6).
-0, --packet Display PACKET sockets (alias for -f link).
-t, --tcp Display TCP sockets.
-u, --udp Display UDP sockets.
-d, --dccp Display DCCP sockets.
-w, --raw Display RAW sockets.
-x, --unix Display Unix domain sockets (alias for -f unix).
-S, --sctp Display SCTP sockets.
--vsock Display vsock sockets (alias for -f vsock).
--xdp Display XDP sockets (alias for -f xdp).
--inet-sockopt Display inet socket options.
-f FAMILY, --family=FAMILY Display sockets of type FAMILY. Currently the following families are supported: unix, inet, inet6, link, netlink, vsock, xdp.
-A QUERY, --query=QUERY, --socket=QUERY List of socket tables to dump, separated by commas. The following identifiers are understood: all, inet, tcp, udp, raw, unix, packet, netlink, unix_dgram, unix_stream, unix_seqpacket, packet_raw, packet_dgram, dccp, sctp, vsock_stream, vsock_dgram, xdp Any item in the list may optionally be prefixed by an exclamation mark (!) to exclude that socket table from being dumped.
-D FILE, --diag=FILE Do not display anything, just dump raw information about TCP sockets to FILE after applying filters. If FILE is - stdout is used.
-F FILE, --filter=FILE Read filter information from FILE. Each line of FILE is interpreted like single command line option. If FILE is - stdin is used.

Example usage of ss command:

To use the ss command, open a terminal and type ss followed by any desired options and arguments. Some common options and arguments include:

  1. Show all listening TCP ports, including the corresponding process.
    1. $ ss -tlp
      State       Recv-Q      Send-Q           Local Address:Port            Peer Address:Port      Process
      LISTEN      0           5                      0.0.0.0:900                  0.0.0.0:*
      LISTEN      0           5                    127.0.0.1:8998                 0.0.0.0:*
      LISTEN      0           128                  127.0.0.1:44309                0.0.0.0:*
      LISTEN      0           128                    0.0.0.0:ssh                  0.0.0.0:*
      LISTEN      0           4096                         *:922                        *:*
      LISTEN      0           4096                         *:970                        *:*
      LISTEN      0           4096                         *:980                        *:*
      LISTEN      0           128                       [::]:ssh                     [::]:*
      
  2. Display timer information.
    1. $ ss -tno
      State Recv-Q Send-Q         Local Address:Port              Peer Address:Port  Process
      ESTAB 0      0                  127.0.0.1:33616                127.0.0.1:22     timer:(keepalive,11sec,0)
      ESTAB 0      0                  127.0.0.1:22                   127.0.0.1:33616  timer:(keepalive,108min,0)
      ESTAB 0      0                  127.0.0.1:22                   127.0.0.1:33632  timer:(keepalive,108min,0)
      ESTAB 0      0                  127.0.0.1:33632                127.0.0.1:22     timer:(keepalive,,0)
      ESTAB 0      0        [::ffff:172.17.0.4]:980     [::ffff:10.191.235.12]:47894  timer:(keepalive,,0)
      ESTAB 0      0        [::ffff:172.17.0.4]:980     [::ffff:10.191.238.12]:56680  timer:(keepalive,11sec,0)
  3. Show all TCP/UDP/RAW/UNIX sockets:ss -a -t|-u|-w|-x

You can also use the ss command to display specific sockets or connections by specifying the protocol, local address, local port, peer address, or peer port as an argument. For example, to display all listening TCP sockets on port 8089, you can use the following command:

$ ss -tl 'sport = :8089'
State      Recv-Q Send-Q Local Address:Port               Peer Address:Port              
LISTEN     0      128    0.0.0.0:8089                      0.0.0.0:*  

Use ss command with -tupln flags to list all sockets and the process in Linux (gnome-terminal)

Conclusion

The ss command is a powerful and useful tool for troubleshooting and analyzing network connections in a Linux system. It provides more information and options than the deprecated netstat command and is an essential tool for network administrators and system administrators.



About the author:
Pradeep has expertise in Linux, Go, Nginx, Apache, CyberSecurity, AppSec and various other technical areas. He has contributed to numerous publications and websites, providing his readers with insightful and informative content.