当前位置: 首页 > news >正文

Linux网络诊断利器:ss命令详解

Linux网络诊断利器:ss命令详解

在这里插入图片描述

在Ubuntu 22.04.1 LTS系统中,ss命令是一个功能强大的网络诊断工具,用于查看详细的套接字统计信息。它是netstat命令的现代替代品,提供了更快的执行速度更详细的连接信息,特别适用于高负载的服务器环境。

1 ss命令简介

ss(Socket Statistics)是Linux系统下一个高级工具,用于查看系统套接字信息。与传统的netstat命令相比,ss直接从内核空间获取信息,效率更高,显示的信息更为详细。当服务器上的socket连接数量非常大时,使用netstat命令可能会很慢,而ss利用TCP协议栈中的tcp_diag模块获取内核第一手信息,因此性能要好很多

2 基本用法与常用选项

2.1 基本语法

ss [选项] [过滤条件]

2.2 常用选项

root@wangge:~# ss --help
Usage: ss [ OPTIONS ]ss [ OPTIONS ] [ FILTER ]-h, --help          this message-V, --version       output version information-n, --numeric       don't resolve service names-r, --resolve       resolve host names-a, --all           display all sockets-l, --listening     display listening sockets-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--tipcinfo      show internal tipc socket information-s, --summary       show socket usage summary--tos           show tos and priority information--cgroup        show cgroup information-b, --bpf           show bpf filter socket information-E, --events        continually display sockets as they are destroyed-Z, --context       display process SELinux security contexts-z, --contexts      display process and socket SELinux security contexts-N, --net           switch to the specified network namespace name-4, --ipv4          display only IP version 4 sockets-6, --ipv6          display only IP version 6 sockets-0, --packet        display PACKET sockets-t, --tcp           display only TCP sockets-M, --mptcp         display only MPTCP sockets-S, --sctp          display only SCTP sockets-u, --udp           display only UDP sockets-d, --dccp          display only DCCP sockets-w, --raw           display only RAW sockets-x, --unix          display only Unix domain sockets--tipc          display only TIPC sockets--vsock         display only vsock sockets-f, --family=FAMILY display sockets of type FAMILYFAMILY := {inet|inet6|link|unix|netlink|vsock|tipc|xdp|help}-K, --kill          forcibly close sockets, display what was closed-H, --no-header     Suppress header line-O, --oneline       socket's data printed on a single line--inet-sockopt  show various inet socket options-A, --query=QUERY, --socket=QUERYQUERY := {all|inet|tcp|mptcp|udp|raw|unix|unix_dgram|unix_stream|unix_seqpacket|packet|netlink|vsock_stream|vsock_dgram|tipc}[,QUERY]-D, --diag=FILE     Dump raw information about TCP sockets to FILE-F, --filter=FILE   read filter information from FILEFILTER := [ state STATE-FILTER ] [ EXPRESSION ]STATE-FILTER := {all|connected|synchronized|bucket|big|TCP-STATES}TCP-STATES := {established|syn-sent|syn-recv|fin-wait-{1,2}|time-wait|closed|close-wait|last-ack|listening|closing}connected := {established|syn-sent|syn-recv|fin-wait-{1,2}|time-wait|close-wait|last-ack|closing}synchronized := {established|syn-recv|fin-wait-{1,2}|time-wait|close-wait|last-ack|closing}bucket := {syn-recv|time-wait}big := {established|syn-sent|fin-wait-{1,2}|closed|close-wait|last-ack|listening|closing}
root@wangge:~#
选项说明
-h, --help显示帮助信息
-V, --version显示版本号
-t, --tcp显示TCP协议的sockets
-u, --udp显示UDP协议的sockets
-x, --unix显示Unix domain sockets
-n, --numeric不解析服务名称,直接显示端口号
-l, --listening只显示监听状态的端口
-a, --all显示所有sockets(监听和非监听)
-p, --processes显示使用socket的进程
-s, --summary显示socket使用摘要
-4, --ipv4仅显示IPv4的sockets
-6, --ipv6仅显示IPv6的sockets
-r, --resolve将IP解析为域名,端口解析为服务名

3 实用示例

3.1 查看所有连接

不添加任何选项时,ss命令默认显示所有已建立的连接(不包含监听端口),包括TCP、UDP和UNIX socket三种类型的连接。

root@wangge:~# ss |head
Netid State    Recv-Q Send-Q                        Local Address:Port       Peer Address:Port   Process
u_dgr ESTAB    0      0                       /run/systemd/notify 24664                 * 0
u_dgr ESTAB    0      0              /run/systemd/journal/dev-log 24702                 * 0
u_dgr ESTAB    0      0               /run/systemd/journal/socket 24704                 * 0
u_dgr ESTAB    0      0                                         * 31349                 * 24704
u_str ESTAB    0      0                                         * 35157                 * 35174
u_str ESTAB    0      0               /run/systemd/journal/stdout 35140                 * 37020
u_str ESTAB    0      0                                         * 38118                 * 35173
u_str ESTAB    0      0               /run/systemd/journal/stdout 25069                 * 37932
u_str ESTAB    0      0               /run/systemd/journal/stdout 342523                * 335663

在这里插入图片描述

3.2 查看监听端口

# 显示所有监听端口
ss -l# 显示所有TCP监听端口
ss -lt# 显示所有UDP监听端口
ss -lu# 以数字形式显示监听端口(不解析服务名)
ss -ln

3.3 按协议查看

  • 显示所有TCP连接
root@wangge:~# ss -t
State          Recv-Q           Send-Q                     Local Address:Port                       Peer Address:Port           Process
ESTAB          0                0                          192.168.3.251:ssh                       192.168.3.102:51230
ESTAB          0                52                         192.168.3.251:ssh                       192.168.3.102:51229
ESTAB          0                0                          192.168.3.251:ssh                       192.168.3.107:65137
ESTAB          0                409                        192.168.3.251:47548                     54.171.230.55:https
ESTAB          0                0                          192.168.3.251:ssh                       192.168.3.107:65138
  • 显示所有UDP连接
root@wangge:~# ss -u
Recv-Q             Send-Q                         Local Address:Port                           Peer Address:Port              Process
0                  0                              192.168.3.251:54368                         192.168.3.254:domain
  • 显示所有UNIX socket连接
ss -x

在这里插入图片描述

3.4 查看进程信息

使用-p选项可以查看使用socket的进程信息,在Ubuntu上通常需要sudo权限。

root@wangge:~# sudo ss -tp
State       Recv-Q       Send-Q               Local Address:Port                Peer Address:Port        Process
ESTAB       0            0                    192.168.3.251:ssh                192.168.3.102:51230        users:(("sshd",pid=575444,fd=4))
ESTAB       0            0                    192.168.3.251:ssh                192.168.3.102:51229        users:(("sshd",pid=575341,fd=4))
ESTAB       0            0                    192.168.3.251:ssh                192.168.3.107:65137        users:(("sshd",pid=534577,fd=4))
ESTAB       0            0                    192.168.3.251:ssh                192.168.3.107:65138        users:(("sshd",pid=534638,fd=4))

在这里插入图片描述

3.5 查看连接摘要

使用-s选项可以查看系统socket统计信息的摘要。

root@wangge:~# ss -s
Total: 381
TCP:   44 (estab 4, closed 1, orphaned 0, timewait 0)Transport Total     IP        IPv6
RAW	  1         0         1
UDP	  24        14        10
TCP	  43        27        16
INET	  68        41        27
FRAG	  0         0         0

在这里插入图片描述

3.6 不解析主机名和服务名

使用-n选项可以阻止ss命令将IP地址解析为主机名,端口号解析为服务名。

root@wangge:~# ss -tn
State           Recv-Q           Send-Q                     Local Address:Port                      Peer Address:Port           Process
ESTAB           0                0                          192.168.3.251:22                       192.168.3.102:51230
ESTAB           0                52                         192.168.3.251:22                       192.168.3.102:51229
ESTAB           0                0                          192.168.3.251:22                       192.168.3.107:65137
ESTAB           0                0                          192.168.3.251:22                       192.168.3.107:65138

4 高级过滤功能

ss命令提供了强大的过滤功能,可以精确查找特定的连接。

4.1 按地址和端口过滤

# 匹配目标地址和端口
ss dst 192.168.1.5
ss dst 192.168.1.5:http
ss dst 192.168.1.5:443# 匹配源地址和端口
ss src 192.168.1.10
ss src 192.168.1.10:ssh
ss src 192.168.1.10:22

4.2 按端口号比较过滤

  • 显示源端口小于50的所有连接
root@wangge:~# ss -tunl sport lt 50
Netid         State          Recv-Q         Send-Q                 Local Address:Port                  Peer Address:Port         Process
tcp           LISTEN         0              128                          0.0.0.0:22                         0.0.0.0:*
tcp           LISTEN         0              128                             [::]:22                            [::]:*
tcp           LISTEN         0              32                                 *:21                               *:*
  • 显示目标端口大于1024的所有TCP连接
root@wangge:~# ss -ta dport gt 1024
State           Recv-Q           Send-Q                     Local Address:Port                      Peer Address:Port           Process
ESTAB           0                0                          192.168.3.251:ssh                      192.168.3.102:51230
ESTAB           0                52                         192.168.3.251:ssh                      192.168.3.102:51229
ESTAB           0                0                          192.168.3.251:ssh                      192.168.3.107:65137
ESTAB           0                0                          192.168.3.251:ssh                      192.168.3.107:65138

端口比较操作符:

操作符缩写含义
<=le小于或等于
>=ge大于或等于
==eq等于
!=ne不等于
>gt大于
<lt小于

4.3 按TCP状态过滤

ss命令可以按照TCP状态进行过滤,常见的状态有:establishedsyn-sentsyn-recvfin-wait-1fin-wait-2time-waitclosedclose-waitlast-acklisteningclosing

# 显示所有已建立的TCP连接
ss -4 state established# 显示所有监听状态的连接
ss -4 state listening# 显示所有TIME-WAIT状态的TCP连接
ss -4 state time-wait

此外,还可以使用以下特殊状态类别:

  • all - 所有状态
  • connected - 除了listeningclosing之外的所有状态
  • synchronized - 除了syn-sent之外的所有状态
  • bucket - 维护的状态,如time-waitsyn-recv
  • big - 与bucket相反的状态

4.4 组合过滤

# 显示所有已建立的HTTP连接
ss -4 state established '( dport = :http or sport = :http )'# 显示所有连接到22端口的连接
ss state all dport = :22# 显示所有状态为established的SSH连接
ss -4 state established sport = :ssh

5 实际应用场景

5.1 查看服务监听状态

# 查看SSH服务是否在监听
ss -ltn | grep ':22'# 查看Web服务是否在监听
ss -ltn | grep ':80'

5.2 排查连接问题

# 查看所有异常连接状态
ss -ta | grep -E "(CLOSE_WAIT|TIME_WAIT|FIN_WAIT)"# 查看是否有过多TIME_WAIT连接(可能需调整内核参数)
ss -ta | grep TIME_WAIT | wc -l

5.3 监控应用连接

# 查看特定进程(如Nginx)的连接
sudo ss -tp | grep nginx# 查看特定用户的连接
sudo ss -tp | grep "users:.*(.*)"

在这里插入图片描述

6 性能优化提示

  1. 使用-n选项避免DNS解析:当连接数较多时,DNS解析会显著降低命令执行速度

  2. 精确过滤:尽量使用过滤条件缩小输出范围,避免处理大量不必要的数据

  3. 结合其他工具:可以将ss输出与grepawk等工具结合,进行进一步处理和分析

总结

在Ubuntu 22.04.1 LTS系统中,ss命令是网络诊断和故障排除的重要工具。它提供了比netstat更快的速度和更详细的信息,特别适合在高负载的服务器环境下使用。通过掌握ss命令的各种选项和过滤技巧,您可以快速定位网络问题,监控系统网络状态,确保网络服务的稳定运行。

http://www.dtcms.com/a/525063.html

相关文章:

  • 北京网站建设公司 蓝纤科技 网络服务网站一般多长
  • 注册qq空间网站wordpress 屏蔽评论
  • 有哪些网站可以做笔译中国建设机械职业教育网证书查询
  • 轨道平面系与轨道姿态系
  • 前端十年回顾及未来展望
  • JavaScript 中,数组去重
  • JavaScript深入之函数组合详解
  • Serverless 应用引擎 SAE:为传统应用托底,为 AI 创新加速
  • Edge-TTS+Cloudflare Worker:免费 TTS 服务搭建指南,支持 API 调用与低代码集成
  • 企业建网站平台找人做购物网站
  • 【javaFX基础】 “Not on FX application thread; currentThread = Thread-3“问题解决方法
  • 专业的网站开发服务window2008 网站建设
  • Linux 查找文件
  • 法术施放选择目标逻辑概述
  • 后台管理网站开发找客户在公司做网站
  • 做游戏陪玩网站江苏省建设厅的官方网站
  • 青岛科技大学《Nano Res.》:0.5秒合成双单原子催化剂!锌空电池稳定运行650小时,氯碱电解效率达97%
  • 力扣 11. 盛最多水的容器 - Java版
  • 狗和人做网站旅游网站框架
  • 网站搭建公司排行榜网站要求
  • n8n网页抓取自动化完整指南
  • Alpine Linux:轻量、安全与高效的Linux发行版
  • 第四章、路由配置
  • Node.js:JavaScript的服务器端革命
  • C++动态内存管理详解:new/delete与malloc/free深度对比
  • 危险网站提示门户网站是如何做引流的
  • 网站代码怎么打开清风网站建设
  • Spring Boot 1.x、2.x 3.x区别汇总
  • 房产网站建设接单公关策划书模板范文
  • three.js加载三维GLB文件,查看三维模型