Linux网络状态工具ss命令使用详解

简介:

原文参考:http://www.ttlsa.com/linux-command/ss-replace-netstat/


ss命令用于显示socket状态. 他可以显示PACKET sockets, TCP sockets, UDP sockets, DCCP sockets, RAW sockets, Unix domain sockets等等统计. 它比其他工具展示等多tcp和state信息. 它是一个非常实用、快速、有效的跟踪IP连接和sockets的新工具.SS命令可以提供如下信息:

  • 所有的TCP sockets

  • 所有的UDP sockets

  • 所有ssh/ftp/ttp/https持久连接

  • 所有连接到Xserver的本地进程

  • 使用state(例如:connected, synchronized, SYN-RECV, SYN-SENT,TIME-WAIT)、地址、端口过滤

  • 所有的state FIN-WAIT-1 tcpsocket连接以及更多

很多流行的Linux发行版都支持ss以及很多监控工具使用ss命令.熟悉这个工具有助于您更好的发现与解决系统性能问题.本人强烈建议使用ss命令替代netstat部分命令,例如netsat -ant/lnt等.

展示他之前来做个对比,统计服务器并发连接数

1
2
3
4
5
6
7
8
9
10
11
12
13
  netstat
# time netstat -ant | grep EST | wc -l
3100
  
real  0m12 . 960s
user  0m0 . 334s
sys  0m12 . 561s
# time ss -o state established | wc -l
3204
  
real  0m0 . 030s
user  0m0 . 005s
sys  0m0 . 026s

结果很明显ss统计并发连接数效率完败netstat,在ss能搞定的情况下, 你还会在选择netstat吗, 还在犹豫吗, 看以下例子,或者跳转到帮助页面.

常用ss命令:

ss -l 显示本地打开的所有端口

ss -pl 显示每个进程具体打开的socket

ss -t -a 显示所有tcp socket

ss -u -a 显示所有的UDP Socekt

ss -o state established '( dport = :smtp or sport = :smtp )显示所有已建立的SMTP连接

ss -o state established '( dport = :http or sport = :http )显示所有已建立的HTTP连接

ss -x src /tmp/.X11-unix/* 找出所有连接X服务器的进程

ss -s 列出当前socket详细信息:


显示sockets简要信息
列出当前已经连接,关闭,等待的tcp连接

1
2
3
4
5
6
7
8
9
10
11
# ss -s
Total:  3519  (kernel  3691 )
TCP:  26557  (estab  3163 , closed  23182 , orphaned  194 , synrecv  0 , timewait  23182 / 0 ), ports  1452
  
Transport Total IP IPv6
*  3691  -  -
RAW  2  2  0
UDP  10  7  3
TCP  3375  3368  7
INET  3387  3377  10
FRAG  0  0  0

列出当前监听端口

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# ss -l
Recv - Q Send - Q Local Address:Port Peer Address:Port
0  10  ::: 5989  ::: *
0  5  * :rsync  * : *
0  128  :::sunrpc ::: *
0  128  * :sunrpc  * : *
0  511  * :http  * : *
0  128  :::ssh ::: *
0  128  * :ssh  * : *
0  128  ::: 35766  ::: *
0  128  127.0 . 0.1 :ipp  * : *
0  128  :: 1 :ipp ::: *
0  100  :: 1 :smtp ::: *
0  100  127.0 . 0.1 :smtp  * : *
0  511  * :https  * : *
0  100  ::: 1311  ::: *
0  5  * : 5666  * : *
0  128  * : 3044  * : *

ss列出每个进程名及其监听的端口

# ss -pl

ss列所有的tcp sockets

# ss -t -a

ss列出所有udp sockets

# ss -u -a

ss列出所有http连接中的连接

# ss -o state established '( dport = :http or sport = :http )'

·以上包含对外提供的80,以及访问外部的80

·用以上命令完美的替代netstat获取http并发连接数,监控中常用到

ss列出本地哪个进程连接到x server

# ss -x src /tmp/.X11-unix/*

ss列出处在FIN-WAIT-1状态的http、https连接

ss -o state fin-wait-1 '( sport = :http or sport = :https )'


ss常用的state状态

established

syn-sent

syn-recv

fin-wait-1

fin-wait-2

time-wait

closed

close-wait

last-ack

listen

closing

all : All of the above states

connected : All the states except for listen and closed

synchronized : All the connected states except for syn-sent

bucket : Show states, which are maintained as minisockets, i.e. time-wait and syn-recv.

big : Opposite to bucket state.



ss使用IP地址筛选


1
2
3
4
5
6
7
8
9
10
ss src ADDRESS_PATTERN
src:表示来源
ADDRESS_PATTERN:表示地址规则
  
如下:
ss src  120.33 . 31.1  # 列出来之20.33.31.1的连接
  
# 列出来至 120.33 . 31.1 , 80 端口的连接
ss src  120.33 . 31.1 :http
ss src  120.33 . 31.1 : 80


ss使用端口筛选

1
2
3
4
ss dport OP PORT
OP:是运算符
PORT:表示端口
dport:表示过滤目标端口、相反的有sport


OP运算符如下:

1
2
3
4
< =  or  le : 小于等于 > =  or  ge : 大于等于
= =  or  eq : 等于
! =  or  ne : 不等于端口
or  lt : 小于这个端口 >  or  gt : 大于端口


OP实例

1
2
3
4
5
6
7
8
9
10
ss sport  =  :http 也可以是 ss sport  =  : 80
ss dport  =  :http
ss dport \> : 1024
ss sport \> : 1024
ss sport \< : 32000
ss sport eq : 22
ss dport ! =  : 22
ss state connected sport  =  :http
ss \( sport  =  :http  or  sport  =  :https \)
ss  - o state fin - wait - 1  \( sport  =  :http  or  sport  =  :https \) dst  192.168 . 1 / 24



为什么ss比netstat快:
netstat是遍历/proc下面每个PID目录,ss直接读/proc/net下面的统计信息。所以ss执行的时候消耗资源以及消耗的时间都比netstat少很多

ss命令帮助

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# ss -h
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
    - s,  - - summary        show socket usage summary
  
    - 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
    - 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
    - f,  - - family = FAMILY display sockets of  type  FAMILY
    - A,  - - query = QUERY,  - - socket = QUERY
        QUERY : =  { all |inet|tcp|udp|raw|unix|packet|netlink}[,QUERY]
  
    - D,  - - diag = FILE       Dump raw information about TCP sockets to  FILE
    - F,  - - filter = FILE    read  filter  information  from  FILE
        FILTER  : =  [ state TCP - STATE ] [ EXPRESSION ]





      本文转自Tenderrain 51CTO博客,原文链接:http://blog.51cto.com/tenderrain/1975721,如需转载请自行联系原作者



相关文章
|
1月前
|
Linux
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
74 24
Linux系统之whereis命令的基本使用
|
4月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
418 8
|
4月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
1296 6
|
4月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
271 3
|
5天前
|
Linux
Linux od命令
本文详细介绍了Linux中的 `od`命令,包括其基本语法、常用选项和示例。通过这些内容,你可以灵活地使用 `od`命令查看文件内容,提高分析和调试效率。确保理解每一个选项和示例的实现细节,应用到实际工作中时能有效地处理各种文件查看需求。
42 19
|
16天前
|
缓存 Ubuntu Linux
Linux中yum、rpm、apt-get、wget的区别,yum、rpm、apt-get常用命令,CentOS、Ubuntu中安装wget
通过本文,我们详细了解了 `yum`、`rpm`、`apt-get`和 `wget`的区别、常用命令以及在CentOS和Ubuntu中安装 `wget`的方法。`yum`和 `apt-get`是高层次的包管理器,分别用于RPM系和Debian系发行版,能够自动解决依赖问题;而 `rpm`是低层次的包管理工具,适合处理单个包;`wget`则是一个功能强大的下载工具,适用于各种下载任务。在实际使用中,根据系统类型和任务需求选择合适的工具,可以大大提高工作效率和系统管理的便利性。
99 25
|
14天前
|
缓存 Linux
Linux查看内存命令
1. free free命令是最常用的查看内存使用情况的命令。它显示系统的总内存、已使用内存、空闲内存和交换内存的总量。 free -h • -h 选项:以易读的格式(如GB、MB)显示内存大小。 输出示例: total used free shared buff/cache available Mem: 15Gi 4.7Gi 4.1Gi 288Mi 6.6Gi 9.9Gi Swap: 2.0Gi 0B 2.0Gi • to
27 2
|
2月前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
53 11
|
4月前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
126 56