Linux網絡監控狀態--ss命令


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也可以正常運行,只是效率會變得稍慢。

語法

ss [參數] 
ss [參數] [過濾]

選項

-h, --help      幫助信息
-V, --version   程序版本信息
-n, --numeric   不解析服務名稱
-r, --resolve   解析主機名
-a, --all       顯示所有套接字(sockets)
-l, --listening 顯示監聽狀態的套接字(sockets)
-o, --options   顯示計時器信息
-e, --extended  顯示詳細的套接字(sockets)信息
-m, --memory    顯示套接字(socket)的內存使用情況
-p, --processes 顯示使用套接字(socket)的進程
-i, --info      顯示 TCP內部信息
-s, --summary   顯示套接字(socket)使用概況
-4, --ipv4      僅顯示IPv4的套接字(sockets)
-6, --ipv6      僅顯示IPv6的套接字(sockets)
-0, --packet    顯示 PACKET 套接字(socket)
-t, --tcp       僅顯示 TCP套接字(sockets)
-u, --udp       僅顯示 UCP套接字(sockets)
-d, --dccp      僅顯示 DCCP套接字(sockets)
-w, --raw       僅顯示 RAW套接字(sockets)
-x, --unix      僅顯示 Unix套接字(sockets)
-f, --family=FAMILY  顯示 FAMILY類型的套接字(sockets),FAMILY可選,支持  unix, inet, inet6, link, netlink
-A, --query=QUERY, --socket=QUERY
      QUERY := {all|inet|tcp|udp|raw|unix|packet|netlink}[,QUERY]
-D, --diag=FILE     將原始TCP套接字(sockets)信息轉儲到文件
 -F, --filter=FILE  從文件中都去過濾器信息
       FILTER := [ state TCP-STATE ] [ EXPRESSION ]

ss指令使用的問題

在對網絡服務連接狀況上,三者之間最好的工具是ss --- 因為其執行速度最快,條件過濾豐富(但也有缺點,輸出不美觀,需column再格式化),為什么把這個指令放在最后,是有原因的。因為最初通過ss 實現lsof -i:port功能時,發現未能有想要的結果輸出。如下:

[root@361way.com ~]# ss -lp|grep 9160
[root@361way.com ~]# ss -ap|grep 9160
[root@361way.com ~]# ss '( sport = :9160 or sport = :9160 )'|more
State      Recv-Q Send-Q      Local Address:Port          Peer Address:Port
ESTAB      0      0           192.168.21.37:apani1       192.168.17.74:58108
ESTAB      0      0           192.168.21.37:apani1       192.168.17.82:46564
………………………………

有沒有發現問題,grep時,發現查詢不到9160端口,通過指定端口查看連接時,發現又有連接。為什么呢?其實同樣是IP反解析域名、端口反解析成服務出的問題,這里本該顯示為端口9160的地方顯示成了apani1,通過查看services文件發現如下:

# cat /etc/services |grep 9160
apani1             9160/tcp     # apani1  [Neal_Taylor]
apani1             9160/udp     # apani1  [Neal_Taylor]

取消端口轉換為服務名后,執行結果如下:

# time ss -lnp|grep 9160
0      50                 192.168.21.37:9160                          *:*      users:(("java",28894,563))
real    0m0.284s
user    0m0.088s
sys     0m0.192s

實例

ss -t -a    # 顯示TCP連接
ss -s       # 顯示 Sockets 摘要
ss -l       # 列出所有打開的網絡連接端口
ss -pl      # 查看進程使用的socket
ss -lp | grep 3306  # 找出打開套接字/端口應用程序
ss -u -a    顯示所有UDP Sockets
ss -o state established '( dport = :smtp or sport = :smtp )' # 顯示所有狀態為established的SMTP連接
ss -o state established '( dport = :http or sport = :http )' # 顯示所有狀態為Established的HTTP連接
ss -o state fin-wait-1 '( sport = :http or sport = :https )' dst 193.233.7/24  # 列舉出處於 FIN-WAIT-1狀態的源端口為 80或者 443,目標網絡為 193.233.7/24所有 tcp套接字

# ss 和 netstat 效率對比
time netstat -at
time ss

# 匹配遠程地址和端口號
# ss dst ADDRESS_PATTERN
ss dst 192.168.1.5
ss dst 192.168.119.113:http
ss dst 192.168.119.113:smtp
ss dst 192.168.119.113:443

# 匹配本地地址和端口號
# ss src ADDRESS_PATTERN
ss src 192.168.119.103
ss src 192.168.119.103:http
ss src 192.168.119.103:80
ss src 192.168.119.103:smtp
ss src 192.168.119.103:25

常用命令:

ss -tnpl |column -t (column指令只是為了格式化對齊,看起來更整潔) 和 netstat -nutlp 效果是一樣的。

 

統計服務器並發連接數

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嗎, 還在猶豫嗎, 看以下例子,或者跳轉到幫助頁面.

 

參考地址:http://www.ttlsa.com/linux-command/ss-replace-netstat/

參考地址:https://wangchujiang.com/linux-command/c/ss.html

參考地址:http://www.361way.com/lsof-ss-netstat/4351.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM