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比。
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比。