ss
查看连接数
连接数
常用选项
-h, --help 帮助
-V, --version 显示版本号
-t, --tcp 显示 TCP 协议的 sockets
-u, --udp 显示 UDP 协议的 sockets
-x, --unix 显示 unix domain sockets,与 -f 选项相同
-n, --numeric 不解析服务的名称,如 "22" 端口不会显示成 "ssh"
-l, --listening 只显示处于监听状态的端口
-p, --processes 显示监听端口的进程(Ubuntu 上需要 sudo)
-a, --all 对 TCP 协议来说,既包含监听的端口,也包含建立的连接
-r, --resolve 把 IP 解释为域名,把端口号解释为协议名称
http://www.cnblogs.com/ggzss/archive/2011/09/25/2190404.html
状态:描述
CLOSED: 表示初始状态。
LISTEN: 表示服务器端的某个SOCKET处于监听状态,可以接受连接了。
SYN_RCVD: 这个状态表示接受到了SYN报文,在正常情况下,这个状态是服务器端的SOCKET在建立TCP连接时的三次握手会话过程中的一个中间状态,很短暂,基本上用netstat你是很难看到这种状态的,除非你特意写了一个客户端测试程序,故意将三次TCP握手过程中最后一个ACK报文不予发送。因此这种状态时,当收到客户端的ACK报文后,它会进入到ESTABLISHED状态。
SYN_SENT: 这个状态与SYN_RCVD遥想呼应,当客户端SOCKET执行CONNECT连接时,它首先发送SYN报文,因此也随即它会进入到了SYN_SENT状态,并等待服务端的发送三次握手中的第2个报文。SYN_SENT状态表示客户端已发送SYN报文。
ESTABLISHED:表示连接已经建立了,正在通信。
FIN_WAIT_1: 这个状态要好好解释一下,其实FIN_WAIT_1和FIN_WAIT_2状态的真正含义都是表示等待对方的FIN报文。而这两种状态的区别是:FIN_WAIT_1状态实际上是当SOCKET在ESTABLISHED状态时,它想主动关闭连接,向对方发送了FIN报文,此时该SOCKET即进入到FIN_WAIT_1状态。而当对方回应ACK报文后,则进入到FIN_WAIT_2状态,当然在实际的正常情况下,无论对方何种情况下,都应该马上回应ACK报文,所以FIN_WAIT_1状态一般是比较难见到的,而FIN_WAIT_2状态还有时常常可以用netstat看到。
FIN_WAIT_2:上面已经详细解释了这种状态,实际上FIN_WAIT_2状态下的SOCKET,表示半连接,也即有一方要求close连接,但另外还告诉对方,我暂时还有点数据需要传送给你,稍后再关闭连接。
TIME_WAIT: 表示收到了对方的FIN报文,并发送出了ACK报文,就等两倍最大段生命周期2MSL(默认4分钟)后即可回到CLOSED可用状态了。如果FIN_WAIT_1状态下,收到了对方同时带FIN标志和ACK标志的报文时,可以直接进入到TIME_WAIT状态,而无须经过FIN_WAIT_2状态。TIME_WAIT 表示主动关闭.
CLOSING: 这种状态比较特殊,实际情况中应该是很少见,属于一种比较罕见的例外状态。正常情况下,当你发送FIN报文后,按理来说是应该先收到(或同时收到)对方的ACK报文,再收到对方的FIN报文。但是CLOSING状态表示你发送FIN报文后,并没有收到对方的ACK报文,反而却也收到了对方的FIN报文。什么情况下会出现此种情况呢?其实细想一下,也不难得出结论:那就是如果双方几乎在同时close一个SOCKET的话,那么就出现了双方同时发送FIN报文的情况,也即会出现CLOSING状态,表示双方都正在关闭SOCKET连接。
CLOSE_WAIT: 这种状态的含义其实是表示在等待关闭。怎么理解呢?当对方close一个SOCKET后发送FIN报文给自己,你系统毫无疑问地会回应一个ACK报文给对方,此时则进入到CLOSE_WAIT状态。接下来呢,实际上你真正需要考虑的事情是察看你是否还有数据发送给对方,如果没有的话,那么你也就可以close这个SOCKET,发送FIN报文给对方,也即关闭连接。所以你在CLOSE_WAIT状态下,需要完成的事情是等待你去关闭连接。CLOSE_WAIT 表示被动关闭
LAST_ACK: 这个状态还是比较容易好理解的,它是被动关闭一方在发送FIN报文后,最后等待对方的ACK报文。当收到ACK报文后,也即可以进入到CLOSED可用状态了。
统计服务器当前单IP连接数最多的IP地址前十
方法1
centos 6
ss -an |egrep '^ESTAB' |awk '{print $1,$5}' |sort |uniq -c |sort -rn -k1 |head -10
centos 7
ss state established |egrep '^tcp' |awk '{print $5}' |cut -d ':' -f1 |sort |uniq -c |sort -rn -k1
ss -n state established |egrep '^tcp' |awk '{print $5}' |cut -d ':' -f1 |sort |uniq -c |sort -rn -k1 |head -n 10
ss -n state established |egrep '^tcp' |awk '{print $5}' |cut -d ':' -f1,2 |sort |uniq -c |sort -rn -k1 | head -n 10 # 统计IP端口数量
-n 只显示端口
方法2
netstat -an|grep EST|awk -F '[ :]+' '{++S[$6]} END {for (key in S) print "ip:"key"----->",S[key]}'|sort -rn -k2
查看端口连接数
ss -o state established '( sport = :3306 or sport = :3306 )' |egrep '^tcp' |wc -l
统计本机LISTEND监听端口
ss -l
ss -lnput
统计远程地址TIME_WAIT
方法1
centos 7
统计ipv4状态TME-WAIT数量台时间
ss state time-wait |egrep '^tcp' |awk '{print $5}' |cut -d ':' -f1 |sort|uniq -c|sort -rn -k1
centos 6
ss -an |egrep '^TIME-WAIT' |awk '{print $1,$5}' |sort |uniq -c |sort -rn -k1 |head -20
统计所有连接状态数
方法1
centos 6
ss -an |awk '{print $1}'|sort|uniq -c|sort -rn
centos 7
ss -an |awk '{print $2}'|sort|uniq -c|sort -rn
方法2
netstat -an | awk '/^tcp/ {++state[$NF]} END {for(key in state) print key,"\t",state[key]}'
匹配远程地址
ss dst 192.168.60.83
匹配本地地址
ss src 127.0.0.1
统计连接端口的ip数量
netstat -nat|grep -i "3306"
netstat -natop|grep "3306" |grep 'ESTABLISHED'
提取日志里访问ip数
grep /07/Sep/2016 mallView_access.log |awk '{a[$1]++}END{for(i in a)print i,a[i]}'