|
一次摸魚的機會,看到群里小伙伴問了一嘴 netstat -tnpl 這個命令是干啥的,這個命令用過很多,但是我其實也沒有認(rèn)真研究過,但是這是一個問題,我不能放過它,而且 netstat 這個命令我日常就用來查詢端口的監(jiān)聽狀態(tài)了,所以趁著這次機會,一起搞懂 netstat 這個命令。 netstat 這個命令在 Linux 、Windows 和 MacOS 操作系統(tǒng)下都兼容,不同的是,netstat 在 UNIX 下顯示詳細(xì)信息的命令是 man netstat ,而在 Linux 和 Windows 下面是 netstat --help。 Linux 下的 netstat 命令當(dāng)我在 Linux 下執(zhí)行 man netstat命令之后,系統(tǒng)顯示出來的提示著實讓我嚇一大跳,看來這個命令內(nèi)容很多??!不要被這么長的描述嚇到,我們一步一步來。 ![]() 首先來了解一下 netstat 這個命令是干啥的。 官方給我們的解釋就是 netstat -- show network status列出網(wǎng)絡(luò)狀態(tài) 但是這網(wǎng)絡(luò)狀態(tài)都有啥呢?帶著疑問,我在 Linux 下執(zhí)行了一下。 ![]() 打印出來是一個六元組,六元組每一列的內(nèi)容分別是 ![]() 仔細(xì)看了一下這個六元組,這好像表明 netstat 這個命令是用于監(jiān)控傳入和傳出的網(wǎng)絡(luò)連接和狀態(tài)的一個命令行工具啊。 從整體上來看,netstst 的輸出結(jié)果可以分為兩部分,一部分是 Active Internet connections,稱為活躍 TCP 連接,其中的 Recv-Q 和 Send-Q 指的是客戶端發(fā)送隊列和客戶端接收隊列。這兩個隊列的值一般都是 0 ,如果不是 0 的話表示有消息堆積還沒有發(fā)出去/取出,這種情況一般很少見到。 另外一部分是 Active UNIX domain sockets, 稱為 活躍的 Unix 域套接字,這部分中的 socket 和網(wǎng)絡(luò) socket 套接字一樣,不同的是,這塊只能用來本地通信,性能要比網(wǎng)絡(luò) socket 高。Active UNIX domain sockets 也是一個六元組,分別表示 ![]() netstat 參數(shù)釋義下面我們來解釋一下 netstat --help 列出來的一些參數(shù),我們從最常見的一些參數(shù)開始入手,這樣大家看起來也能形成階段性記憶,不至于失去重點。 netstat -a-a 這個參數(shù)默認(rèn)會監(jiān)控所有的 socket 連接。 ![]() 包括已經(jīng)監(jiān)聽的、已經(jīng)建立連接的、客戶端發(fā)送的等待服務(wù)器的和未被監(jiān)聽都會被列出來。 netstat -at/-t netstat -at 和 netstat -t 這倆后綴都是用來監(jiān)聽與 TCP 協(xié)議有關(guān)的端口,不同的是 netstat -at 會監(jiān)聽所有 State(狀態(tài))下的端口,而 netstat -t 僅僅會監(jiān)聽 ESTABLISHED 狀態(tài)的端口。 netstat -at ![]() netstat -t ![]() netstat -au/-u 同樣的,netstat -au 和 netstat -u 都會監(jiān)控與 UDP 有關(guān)的端口,不同的是 netstat -au 會監(jiān)聽所有 State(狀態(tài))下的端口,而 netstat -u 僅僅會監(jiān)聽 ESTABLISHED 狀態(tài)的端口。 netstat -au ![]() netstat -u ![]() 我這里測試是沒有監(jiān)控已經(jīng)建立連接狀態(tài)下的 UDP 協(xié)議。 netstat -ap 這條命令用于列出程序運行的端口,常用的命令是 比如我們要找 http 程序,就是 Netstat -ap|grep http ![]() 還可以直接列出端口號 netstat -ap|grep 8080![]()
netstat -lnetstat -l 用于監(jiān)聽正在處于監(jiān)聽狀態(tài)的端口(讀起來還真有那么點費勁,為了讀起來更順暢,后面直接使用列出替換監(jiān)聽)。 ![]() netstat -lt 只用于列出所有監(jiān)聽 TCP 端口。 ![]() netstat -lu 只用于列出所有監(jiān)聽 UDP 端口。 ![]() netstat -lx 只用于列出所有監(jiān)聽 UNIX 端口。 ![]() netstat -snetstat -s用于列出所有端口的統(tǒng)計信息。 ![]() netstat -st用于列出 TCP 端口的統(tǒng)計信息。 ![]() netstat -su用于列出 UDP 端口的統(tǒng)計信息。 ![]() netstat -pnetstat -p 可以與其他參數(shù)一起使用,例如 netstat -pt 就可以列出服務(wù)名稱和 PID 號。 ![]() netstat -c使用 netstat -c 將每隔一秒列出網(wǎng)絡(luò)信息。 ![]() netstat -rnetstat -r用于列出路由核心信息。 ![]() netstat --verbose這條命令會列出系統(tǒng)支持的地址族(Address Family)。 ![]()
netstat -inetstat -i 用來列出網(wǎng)絡(luò)接口數(shù)據(jù)包,包括傳輸和接收具有 MTU(最大傳輸單元)的數(shù)據(jù)包。 ![]() 另外,netstat -ie 還用于列出內(nèi)核接口表,和 ifconfig 命令很相似 ![]() 關(guān)于這個問題所以,回到文章剛開始的那個疑問,netstat -tnpl 是干什么用的,其實這就是幾個參數(shù)的組合
我們執(zhí)行一下這個命令。 ![]() 另外,在 Linux 中,已經(jīng)推薦使用 ss 來替代 netstat ,使用 ip route 來替代 netstat -r ,使用 ip -s link 來替代 netstat -i ,使用 ip addr 來替代 netstat -g 了。 如果這篇文章對你有幫助,希望點贊并關(guān)注一下哦! |
|
|