Linux怎么使用ss命令查看系統的socket狀態?
ss是Socketstatistics的縮寫。顧名思義,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也可以正常運行,只是效率會變得稍慢。(但仍然比netstat要快。) 1.命令格式: ss[參數] ss[參數][過濾] ??2.命令功能: ss(SocketStatistics的縮寫)命令可以用來獲取socket統計信息,此命令輸出的結果類似于netstat輸出的內容,但它能顯示更多更詳細的TCP連接狀態的信息,且比netstat更快速高效。它使用了TCP協議棧中tcp_diag(是一個用于分析統計的模塊),能直接從獲得第一手內核信息,這就使得ss命令快捷高效。在沒有tcp_diag,ss也可以正常運行。 ? 3.命令參數: -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:=[stateTCP-STATE][EXPRESSION] 4.使用實例: 實例1:顯示TCP連接 命令:ss-t-a 輸出: 代碼如下: [root@localhost~]#ss-t-a StateRecv-QSend-QLocalAddress:PortPeerAddress:Port LISTEN00127.0.0.1:smux*:* LISTEN00*:3690*:* LISTEN00*:ssh*:* ESTAB00192.168.120.204:ssh10.2.0.68:49368 [root@localhost~]# 實例2:顯示Sockets摘要 命令:ss-s 輸出:? 代碼如下: [root@localhost~]#ss-s Total:34(kernel48) TCP:4(estab1,closed0,orphaned0,synrecv0,timewait0/0),ports3《/p》《p》TransportTotalIPIPv6 *48-- RAW000 UDP550 TCP440 INET990 FRAG000 [root@localhost~]# 說明:列出當前的established,closed,orphanedandwaitingTCPsockets 實例3:列出所有打開的網絡連接端口 命令:ss-l 輸出: 代碼如下: [root@localhost~]#ss-l Recv-QSend-QLocalAddress:PortPeerAddress:Port 00127.0.0.1:smux*:* 00*:3690*:* 00*:ssh*:* [root@localhost~]# 實例4:查看進程使用的socket 命令:ss-pl 輸出: 代碼如下: [root@localhost~]#ss-pl Recv-QSend-QLocalAddress:PortPeerAddress:Port 00127.0.0.1:smux*:*users:((“snmpd”,2716,8)) 00*:3690*:*users:((“svnserve”,3590,3)) 00*:ssh*:*users:((“sshd”,2735,3)) [root@localhost~]# 實例5:找出打開套接字/端口應用程序 命令:ss-lp|grep3306 輸出: 代碼如下: [root@localhost~]#ss-lp|grep1935 00*:1935*:*users:((“fmsedge”,2913,18)) 00127.0.0.1:19350*:*users:((“fmsedge”,2913,17)) [root@localhost~]#ss-lp|grep3306 00*:3306*:*users:((“mysqld”,2871,10)) [root@localhost~]# 實例6:顯示所有UDPSockets 命令:ss-u-a 輸出: 代碼如下: [root@localhost~]#ss-u-a StateRecv-QSend-QLocalAddress:PortPeerAddress:Port UNCONN00127.0.0.1:syslog*:* UNCONN00*:snmp*:* ESTAB00192.168.120.203:3964110.58.119.119:domain [root@localhost~]# 實例7:顯示所有狀態為established的SMTP連接 命令:ss-ostateestablished‘(dport=:smtporsport=:smtp)’ 輸出: 代碼如下: [root@localhost~]#ss-ostateestablished‘(dport=:smtporsport=:smtp)’ Recv-QSend-QLocalAddress:PortPeerAddress:Port [root@localhost~]# 實例8:顯示所有狀態為Established的HTTP連接 命令:ss-ostateestablished‘(dport=:httporsport=:http)’ 輸出: 代碼如下: [root@localhost~]#ss-ostateestablished‘(dport=:httporsport=:http)’ Recv-QSend-QLocalAddress:PortPeerAddress:Port 0075.126.153.214:2164192.168.10.42:http [root@localhost~]#? 實例9:列舉出處于FIN-WAIT-1狀態的源端口為80或者443,目標網絡為193.233.7/24所有tcp套接字 命令:ss-ostatefin-wait-1‘(sport=:httporsport=:https)’dst193.233.7/24 實例10:用TCP狀態過濾Sockets: 命令: 代碼如下: ss-4stateFILTER-NAME-HERE ss-6stateFILTER-NAME-HERE 輸出: 代碼如下: [root@localhost~]#ss-4stateclosing Recv-QSend-QLocalAddress:PortPeerAddress:Port 11109475.126.153.214:http192.168.10.42:4669 說明: FILTER-NAME-HERE可以代表以下任何一個: 代碼如下: established syn-sent syn-recv fin-wait-1 fin-wait-2 time-wait closed close-wait last-ack listen closing all:所有以上狀態 connected:除了listenandclosed的所有狀態 synchronized:所有已連接的狀態除了syn-sent bucket:顯示狀態為maintainedasminisockets,如:time-wait和syn-recv. big:和bucket相反。 實例11:匹配遠程地址和端口號 命令: 代碼如下: ssdstADDRESS_PATTERN ssdst192.168.1.5 ssdst192.168.119.113:http ssdst192.168.119.113:smtp ssdst192.168.119.113:443 輸出: 代碼如下: [root@localhost~]#ssdst192.168.119.113 StateRecv-QSend-QLocalAddress:PortPeerAddress:Port ESTAB00192.168.119.103:16014192.168.119.113:20229 ESTAB00192.168.119.103:16014192.168.119.113:61056 ESTAB00192.168.119.103:16014192.168.119.113:61623 ESTAB00192.168.119.103:16014192.168.119.113:60924 ESTAB00192.168.119.103:16050192.168.119.113:43701 ESTAB00192.168.119.103:16073192.168.119.113:32930 ESTAB00192.168.119.103:16073192.168.119.113:49318 ESTAB00192.168.119.103:16014192.168.119.113:3844 [root@localhost~]#ssdst192.168.119.113:http StateRecv-QSend-QLocalAddress:PortPeerAddress:Port [root@localhost~]#ssdst192.168.119.113:3844 StateRecv-QSend-QLocalAddress:PortPeerAddress:Port ESTAB00192.168.119.103:16014192.168.119.113:3844 [root@localhost~]# 實例12:匹配本地地址和端口號 命令: 代碼如下: sssrcADDRESS_PATTERN sssrc192.168.119.103 sssrc192.168.119.103:http sssrc192.168.119.103:80 sssrc192.168.119.103:smtp sssrc192.168.119.103:25 輸出: 代碼如下: [root@localhost~]#sssrc192.168.119.103:16021 StateRecv-QSend-QLocalAddress:PortPeerAddress:Port ESTAB00192.168.119.103:16021192.168.119.201:63054 ESTAB00192.168.119.103:16021192.168.119.201:62894 ESTAB00192.168.119.103:16021192.168.119.201:63055 ESTAB00192.168.119.103:16021192.168.119.201:2274 ESTAB00192.168.119.103:16021192.168.119.201:44784 ESTAB00192.168.119.103:16021192.168.119.201:7233 ESTAB00192.168.119.103:16021192.168.119.103:58660 ESTAB00192.168.119.103:16021192.168.119.201:44822 ESTAB00192.168.119.103:1602110.2.1.206:56737 ESTAB00192.168.119.103:1602110.2.1.206:57487 ESTAB00192.168.119.103:1602110.2.1.206:56736 ESTAB00192.168.119.103:1602110.2.1.206:64652 ESTAB00192.168.119.103:1602110.2.1.206:56586 ESTAB00192.168.119.103:1602110.2.1.206:64653 ESTAB00192.168.119.103:1602110.2.1.206:56587 [root@localhost~]# 實例13:將本地或者遠程端口和一個數比較 命令: 代碼如下: ssdportOPPORT sssportOPPORT 輸出: 代碼如下: [root@localhost~]#sssport=:http [root@localhost~]#ssdport=:http [root@localhost~]#ssdport\》:1024 [root@localhost~]#sssport\》:1024 [root@localhost~]#sssport\《:32000 [root@localhost~]#sssporteq:22 [root@localhost~]#ssdport!=:22 [root@localhost~]#ssstateconnectedsport=:http [root@localhost~]#ss\(sport=:httporsport=:https\) [root@localhost~]#ss-ostatefin-wait-1\(sport=:httporsport=:https\)dst192.168.1/24 說明: ssdportOPPORT遠程端口和一個數比較;sssportOPPORT本地端口和一個數比較。 OP可以代表以下任意一個: 《=orle:小于或等于端口號 》=orge:大于或等于端口號 ==oreq:等于端口號 !=orne:不等于端口號 《orgt:小于端口號 》orlt:大于端口號 實例14:ss和netstat效率對比 命令: 代碼如下: timenetstat-at timess 輸出: 代碼如下: [root@localhost~]#timess real0m0.739s user0m0.019s sys0m0.013s [root@localhost~]# [root@localhost~]#timenetstat-at real2m45.907s user0m0.063s sys0m0.067s [root@localhost~]# 說明: 用time命令分別獲取通過netstat和ss命令獲取程序和概要占用資源所使用的時間。在服務器連接數比較多的時候,netstat的效率完全沒法和ss比。