一次摸魚的機會,看到群里小伙伴問了一嘴 netstat -tnpl 這個命令是干啥的,這個命令用過很多,但是我其實也沒有認真研究過,但是這是一個問題,我不能放過它,而且 netstat 這個命令我日常就用來查詢端口的監聽狀態了,所以趁着這次機會,一起搞懂 netstat 這個命令。
netstat 這個命令在 Linux 、Windows 和 MacOS 操作系統下都兼容,不同的是,netstat 在 UNIX 下顯示詳細信息的命令是 man netstat ,而在 Linux 和 Windows 下面是 netstat --help。
Linux 下的 netstat 命令
當我在 Linux 下執行 man netstat命令之后,系統顯示出來的提示着實讓我嚇一大跳,看來這個命令內容很多啊!不要被這么長的描述嚇到,我們一步一步來。
首先來了解一下 netstat 這個命令是干啥的。
官方給我們的解釋就是
netstat -- show network status
列出網絡狀態
但是這網絡狀態都有啥呢?帶着疑問,我在 Linux 下執行了一下。
打印出來是一個六元組,六元組每一列的內容分別是

仔細看了一下這個六元組,這好像表明 netstat 這個命令是用於監控傳入和傳出的網絡連接和狀態的一個命令行工具啊。
從整體上來看,netstst 的輸出結果可以分為兩部分,一部分是 Active Internet connections,稱為活躍 TCP 連接,其中的 Recv-Q 和 Send-Q 指的是客戶端發送隊列和客戶端接收隊列。這兩個隊列的值一般都是 0 ,如果不是 0 的話表示有消息堆積還沒有發出去/取出,這種情況一般很少見到。
另外一部分是 Active UNIX domain sockets, 稱為 活躍的 Unix 域套接字,這部分中的 socket 和網絡 socket 套接字一樣,不同的是,這塊只能用來本地通信,性能要比網絡 socket 高。Active UNIX domain sockets 也是一個六元組,分別表示

netstat 參數釋義
下面我們來解釋一下 netstat --help 列出來的一些參數,我們從最常見的一些參數開始入手,這樣大家看起來也能形成階段性記憶,不至於失去重點。
netstat -a
-a 這個參數默認會監控所有的 socket 連接。
包括已經監聽的、已經建立連接的、客戶端發送的等待服務器的和未被監聽都會被列出來。
netstat -at/-t
netstat -at 和 netstat -t 這倆后綴都是用來監聽與 TCP 協議有關的端口,不同的是 netstat -at 會監聽所有 State(狀態)下的端口,而 netstat -t 僅僅會監聽 ESTABLISHED 狀態的端口。
netstat -at
netstat -t
netstat -au/-u
同樣的,netstat -au 和 netstat -u 都會監控與 UDP 有關的端口,不同的是 netstat -au 會監聽所有 State(狀態)下的端口,而 netstat -u 僅僅會監聽 ESTABLISHED 狀態的端口。
netstat -au
netstat -u
我這里測試是沒有監控已經建立連接狀態下的 UDP 協議。
netstat -ap
這條命令用於列出程序運行的端口,常用的命令是
netstat -ap|grep '程序名'
比如我們要找 http 程序,就是 Netstat -ap|grep http
還可以直接列出端口號
netstat -ap|grep 8080
不過需要注意下,並不是所有的程序都能被找到,沒有權限的不會顯示,使用 root 權限可以查詢所有信息。
netstat -l
netstat -l 用於監聽正在處於監聽狀態的端口(讀起來還真有那么點費勁,為了讀起來更順暢,后面直接使用列出
替換監聽)。
netstat -lt 只用於列出所有監聽 TCP 端口。
netstat -lu 只用於列出所有監聽 UDP 端口。
netstat -lx 只用於列出所有監聽 UNIX 端口。
netstat -s
netstat -s用於列出所有端口的統計信息。
netstat -st用於列出 TCP 端口的統計信息。
netstat -su用於列出 UDP 端口的統計信息。
netstat -p
netstat -p 可以與其他參數一起使用,例如 netstat -pt 就可以列出服務名稱和 PID 號。
netstat -c
使用 netstat -c 將每隔一秒列出網絡信息。
netstat -r
netstat -r用於列出路由核心信息。
netstat --verbose
這條命令會列出系統支持的地址族(Address Family)。
Address Family 簡單來說就是底層是使用的哪種通信協議來遞交數據的,如 AF_INET 用的是 TCP/IPv4;AF_INET6 使用的是 TCP/IPv6;而 AF_LOCAL 或者 AF_UNIX 則指的是本地通信(即本次通信是在當前主機上的進程間的通信),一般用絕對路徑的形式來指明。
netstat -i
netstat -i 用來列出網絡接口數據包,包括傳輸和接收具有 MTU(最大傳輸單元)的數據包。
另外,netstat -ie 還用於列出內核接口表,和 ifconfig 命令很相似
關於這個問題
所以,回到文章剛開始的那個疑問,netstat -tnpl 是干什么用的,其實這就是幾個參數的組合
- -t :僅列出與 tcp 有關的信息
- -n:以數字形式列出
- -p:列出正在使用 socket PID 和 程序名稱
- -l:列出正在監聽的服務器 socket
我們執行一下這個命令。
另外,在 Linux 中,已經推薦使用 ss 來替代 netstat ,使用 ip route 來替代 netstat -r ,使用 ip -s link 來替代 netstat -i ,使用 ip addr 來替代 netstat -g 了。
原文鏈接:netstat 還能這么玩兒?
如果這篇文章對你有幫助,希望點贊並關注一下哦!