ss
比 netstat 好用的socket统计信息,iproute2 包附带的另一个工具,允许你查询 socket 的有关统计信息。
补充说明
ss命令 用来显示处于活动状态的套接字信息。ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容。但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。
当服务器的socket连接数量变得非常大时,无论是使用netstat命令还是直接cat /proc/net/tcp
,执行速度都会很慢。可能你不会有切身的感受,但请相信我,当服务器维持的连接达到上万个的时候,使用netstat等于浪费 生命,而用ss才是节省时间。
天下武功唯快不破。ss快的秘诀在于,它利用到了TCP协议栈中tcp_diag。tcp_diag是一个用于分析统计的模块,可以获得Linux 内核中第一手的信息,这就确保了ss的快捷高效。当然,如果你的系统中没有tcp_diag,ss也可以正常运行,只是效率会变得稍慢。
语法
1 | <!-- more --> |
选项
1 | -h, --help 帮助信息 |
实例
1 | ss -t -a # 显示TCP连接 |
将本地或者远程端口和一个数比较
1 | # ss dport OP PORT 远程端口和一个数比较; |
用TCP 状态过滤Sockets
1 | ss -4 state closing |
显示ICP连接
1 | [root@localhost ~]# ss -t -a |
显示 Sockets 摘要
1 | [root@localhost ~]# ss -s |
列出当前的established, closed, orphaned and waiting TCP sockets
列出所有打开的网络连接端口
1 | [root@localhost ~]# ss -l |
查看进程使用的socket
1 | [root@localhost ~]# ss -pl |
找出打开套接字/端口应用程序
1 | [root@localhost ~]# ss -pl | grep 3306 |
显示所有UDP Sockets
1 | [root@localhost ~]# ss -u -a |
出所有端口为 22(ssh)的连接
1 | ss state all sport = :ssh |