回覆列表
  • 1 # 使用者8161060641431

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

  • 中秋節和大豐收的關聯?
  • 春雨的色彩   春雨,像春姑娘紡出的線,沒完沒了地下到地上,沙沙沙,沙沙沙……  一群小鳥在屋?