新聞中心
如果要在你的系統(tǒng)上監(jiān)控網(wǎng)絡(luò),那么使用命令行工具是非常實(shí)用的,并且對(duì)于 Linux 用戶來(lái)說(shuō),有著許許多多現(xiàn)成的工具可以使用,本篇文章重點(diǎn)為大家詳細(xì)講解一下Linux下常用的網(wǎng)絡(luò)監(jiān)控工具。

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比青河網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式青河網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋青河地區(qū)。費(fèi)用合理售后完善,10年實(shí)體公司更值得信賴。
Netstat
Netstat是Linux下全能的網(wǎng)絡(luò)監(jiān)控工具,可以監(jiān)控主機(jī)網(wǎng)絡(luò)數(shù)據(jù)包統(tǒng)計(jì)信息以及網(wǎng)卡信息的命令行工具。它可以顯示當(dāng)前網(wǎng)絡(luò)連接,路由表以及許多網(wǎng)絡(luò)接口和網(wǎng)絡(luò)協(xié)議統(tǒng)計(jì)信息。netstat在很很多發(fā)行版是默認(rèn)安裝的,比如Centos 6等在centos 7,8下默認(rèn)是用iptraf2 的ss來(lái)取代它,默認(rèn)不在安裝。但是可以安裝。
Ubuntu和Debian用戶可以使用默認(rèn)的apt軟件包管理器安裝。Netstat命令式軟件包net-tools的一部分。并且可以通過(guò)在shell或終端中運(yùn)行以下命令來(lái)安裝:
sudo apt-get install net-tools
CentOS,F(xiàn)edora和RHEL用戶可以使用yum軟件包管理器:
yum install net-tools
安裝后,運(yùn)行以下命令,即可使用Netstat監(jiān)視網(wǎng)絡(luò)數(shù)據(jù)包統(tǒng)計(jì)信息:
netstat
netstat最常用的方法:
netstat -nt(u)lp
用來(lái)查看本機(jī)應(yīng)用監(jiān)聽(tīng)的信息,包括監(jiān)聽(tīng)的網(wǎng)絡(luò)、端口和程序名稱及其Pid
要實(shí)時(shí)查看本機(jī)的網(wǎng)絡(luò)連接情況,需要使用參數(shù)-a
可以列出當(dāng)前的網(wǎng)絡(luò)連接的本地IP和端口,以及遠(yuǎn)程端的IP和端口,以及網(wǎng)絡(luò)連接狀況,可以以此統(tǒng)計(jì)各個(gè)狀態(tài)的鏈接情況,以此來(lái)分析服務(wù)的健康性、進(jìn)行網(wǎng)絡(luò)調(diào)優(yōu)(配置內(nèi)核網(wǎng)絡(luò)參數(shù)),故障排查等。借助一個(gè)單行命令,可以列出當(dāng)前各個(gè)TCP連接狀態(tài)的數(shù)量:
netstat -natlp|perl -lane 'print $F[5]'|sort|uniq -c 2 CLOSE_WAIT 1 established) 29 ESTABLISHED 1 Foreign 23 LISTEN 5 TIME_WAIT
netstat 更常用的一個(gè)方法是,用它查看本機(jī)網(wǎng)絡(luò)(卡)配置狀況,其效果和ifconfig一樣:
netstat -ie
netstat的更多用法,我們可以直接查看器使用手冊(cè)(這適用于所有的Linux命令),方法是在shell或終端中輸入man netstat即可:
man netstat
SS
iproute2提供的SS命令是很多發(fā)行版用于取代netstat的新一代網(wǎng)絡(luò)工具,其獲取信息更快,在網(wǎng)絡(luò)訪問(wèn)量很大的機(jī)器上使用ss可以更快的獲取鏈接情況。
iproute2在很多默認(rèn)發(fā)行版本中可以,也使用以下命令使用包管理器輕松安裝:
sudo apt-get install iproute2 yum install iproute2
SS的使用方法,man ss可以得到信息
-l 顯示本地打開(kāi)的所有端口 -pl 顯示socket進(jìn)程和端口等和netstat -nutlp
-tpl和-upl顯示本地監(jiān)聽(tīng)的TCP和UDP連接情況
-ta 顯示所有TCP連接。-ua 顯示所有的UDP連接。要統(tǒng)計(jì)各個(gè)連接狀況網(wǎng)絡(luò)連接統(tǒng)計(jì),可以使用: ss -a|perl -lane ‘print $F[1]’|sort|uniq -c
在主機(jī)連接數(shù)很大時(shí)候,對(duì)比netstat,ss統(tǒng)計(jì)非???。主要原因是ss的實(shí)現(xiàn)中利用了TCP協(xié)議棧中tcp_diag模塊,可以直接從內(nèi)核獲得相關(guān)網(wǎng)絡(luò)信息。而netstat是通過(guò)讀取/proc/net/tcp信息,然后統(tǒng)計(jì)計(jì)算的,比較慢。
ss支持篩選語(yǔ)法,比如下面:
ss -o state established ‘( dport = :ssh or sport = :ssh )’ 顯示所有已建立的SSH(默認(rèn)端口22)連接 ss -o state established ‘( dport = :http or sport = :http )’ 顯示所有已建立的HTTP連接
可以根據(jù)其他字段進(jìn)行篩選,比如列出本機(jī)(127.0.0.1)的連接,可以用
ss src 127.0.0.1
網(wǎng)絡(luò)流量統(tǒng)計(jì)
1. iftop
如果要按主機(jī)的網(wǎng)絡(luò)帶寬使用情況,通??梢允褂胕ftop。iftop在指定網(wǎng)卡,如果未指定該接口,則顯示所有網(wǎng)絡(luò)流量,并按主機(jī)對(duì)顯示當(dāng)前帶寬使用情況表。
在該統(tǒng)計(jì)窗口,按h,可以獲得幫助信息:
可通過(guò)發(fā)行版包管理安裝iftop:
sudo apt-get install iftop
使用以下命令使用yum在計(jì)算機(jī)上安裝iftop
yum install iftop
2. nethogs
nethogs是一個(gè)免費(fèi)的網(wǎng)絡(luò)統(tǒng)計(jì)工具。nethogs可以根據(jù)進(jìn)程PID來(lái)統(tǒng)計(jì)網(wǎng)絡(luò)流量,因?yàn)樗催M(jìn)程對(duì)帶寬進(jìn)行分組,而不是像大多數(shù)工具一樣按協(xié)議或子網(wǎng)來(lái)統(tǒng)計(jì)。nethogs功能豐富,同時(shí)支持IPv4和IPv6,當(dāng)要統(tǒng)計(jì)Linux主機(jī)帶寬占用信息時(shí),它是最好的實(shí)用程序。nethogs也使用發(fā)行版包安裝直接安裝。
linux用戶可以使用nethogs顯示每個(gè)進(jìn)程的TCP下載和上傳速度,通過(guò)使用命
3. nload
nload是一個(gè)控制臺(tái)應(yīng)用程序,可用于實(shí)時(shí)監(jiān)視網(wǎng)絡(luò)流量和帶寬使用情況,并且通過(guò)提供兩個(gè)易于理解的圖表來(lái)可視化流量。
nload使用非常簡(jiǎn)單,直接使用nload啟動(dòng)即可,無(wú)需額外的命令行選項(xiàng)。還提供了監(jiān)控時(shí)在網(wǎng)卡直接切換的快捷鍵,可以通過(guò)按左右箭頭鍵來(lái)顯示不同網(wǎng)口的流量統(tǒng)計(jì)。
nload工具提供的圖形非常易于理解,提供最有用的統(tǒng)計(jì)信息和其他信息,例如傳輸?shù)臄?shù)據(jù)總量和最小/最大網(wǎng)絡(luò)使用率。
4. lurm
slurm有一個(gè)非常好用的網(wǎng)絡(luò)負(fù)載監(jiān)視工具,它結(jié)果顯示非常簡(jiǎn)練而且還支持許多交互快捷鍵,例如c切換到經(jīng)典模式,s切換到分割圖模式,r重新繪制屏幕,L到啟用TX / RX led,m可以在經(jīng)典分割視圖和大視圖之間切換,q可以退出。
slurm在Ubuntu和Debian系官方倉(cāng)庫(kù)中可用,用戶可以使用apt install命令輕松下載它,如下所示。
apt instal slurm
5. collectl
collectl可用于收集描述當(dāng)前系統(tǒng)狀態(tài)的數(shù)據(jù),并且支持以記錄模式和播放模式。
記錄模式允許從實(shí)時(shí)系統(tǒng)中獲取數(shù)據(jù)并在終端上顯示或?qū)懭胍粋€(gè)或多個(gè)文件或套接字。 播放模式 可以以記錄模式下生成的一個(gè)或多個(gè)數(shù)據(jù)文件中的信息進(jìn)行讀取并顯示。
collectl 可以直接啟動(dòng)就能運(yùn)行,可以顯示系統(tǒng)CPU,磁盤(pán)和網(wǎng)絡(luò)的統(tǒng)計(jì)信息:
可以通過(guò)-s選項(xiàng)制定需要統(tǒng)計(jì)的信息:
Linux網(wǎng)絡(luò)監(jiān)控工具大點(diǎn)兵
例如統(tǒng)計(jì)詳細(xì)的網(wǎng)絡(luò)信息,可以使用collectl -sN
collectl是一個(gè)非常綜合和強(qiáng)大的工具,限于篇幅本文不在展開(kāi),以后有機(jī)會(huì)可以專門(mén)予以介紹。
6. Speedometer
Speedometer是一個(gè)小型且簡(jiǎn)單的工具,它僅通過(guò)給定網(wǎng)口繪制下行和上行流量圖。Speedometer可以使用發(fā)行版管理器通過(guò)以下命令輕松安裝:
sudo apt-get install speedometer 或者 yum install speedometer
speedometer使用非常簡(jiǎn)單,可以直接的命令行或者終端中啟動(dòng)
speedometer -r eth0 -t eth0
7. tcptrack
tcptrack顯示在給定的網(wǎng)絡(luò)接口上看到的TCP連接的狀態(tài)。tcptrack監(jiān)視它們的狀態(tài),并在排序后的更新列表中顯示諸如狀態(tài),源/目標(biāo)地址和帶寬使用情況之類的信息,
tcptrack需要以root權(quán)限或超級(jí)用戶身份運(yùn)行,需要使用要監(jiān)視其TCP連接的網(wǎng)口名稱執(zhí)行:
sudo tcptrack -i eth0
如果要特定端口,可以在網(wǎng)卡名稱用port指明具體端口:
tcptrack -i wlan2 port 80
tcptrack 還支持讀取網(wǎng)絡(luò)抓包.pcap格式的包,并進(jìn)行統(tǒng)計(jì),直接顯示或者,或者保存為文件。
三、網(wǎng)絡(luò)抓包
1. tcpdump
TCPDump是用于對(duì)網(wǎng)絡(luò)監(jiān)控,網(wǎng)絡(luò)包抓取工具。使用tcpdump通過(guò)抓包用于調(diào)試網(wǎng)絡(luò)或服務(wù)器相關(guān)的問(wèn)題。
tcpdump在Debian的默認(rèn)存儲(chǔ)庫(kù)Ubuntu中可用,因此,我們可以簡(jiǎn)單地使用apt manager來(lái)以sudo特權(quán)進(jìn)行安裝。為此,我們需要在Shell或終端中運(yùn)行以下命令。
tcpdump 需要以root權(quán)限或超級(jí)用戶身份運(yùn)行,如果要監(jiān)控TCP連接的網(wǎng)絡(luò)eth0:
sudo tcpdump
可以通過(guò)-i指定具體網(wǎng)口,也可以通過(guò)port來(lái)指定端口(比如web 80)
tcpdump -i eth0 'port 80'
tcp抓包可以抓包結(jié)果保存為pcap文件,然后用其他工具進(jìn)行后續(xù)分析,比如用Wireshark工具進(jìn)行分析:
tcpdump -i eth0 -w aaa.pcap
wireshark aaa.pcap
2. tcpflow
tcpflow也是一個(gè)命令行網(wǎng)絡(luò)抓包程序,用于捕獲作為T(mén)CP連接(流一部分傳輸?shù)臄?shù)據(jù),并以便于協(xié)議分析或調(diào)試的方式存儲(chǔ)數(shù)據(jù)。它重建實(shí)際的數(shù)據(jù)流,并將每個(gè)流存儲(chǔ)在單獨(dú)的文件中,以供以后分析。它了解TCP序列號(hào),并且將正確地重建數(shù)據(jù)流,而不管重傳或無(wú)序傳遞。與tcpdump同,tcpflow是以流為單位顯示數(shù)據(jù)內(nèi)容,而tcpdump以包為單位顯示數(shù)據(jù)。用tcpflow分析會(huì)更便捷。tcpflow默認(rèn)是不在終端打印信息,而是在以源ip.端口-目的ip.端口為文件名在當(dāng)前文件夾下創(chuàng)建文件顯示信息??梢允褂?cp直接的終端打印包信息。
tcpflow -cp
可以用-i制定特定網(wǎng)口 port制定特定端口,比如:
sudo tcpflow -i eth0 port 80
3. wireshark和tshark
wireshark圖形界面工具估計(jì)很多同學(xué)都熟悉,限于篇幅,我們不再介紹。而要介紹的是wireshark的命令行兄弟tshark:
tshark安裝可以使用發(fā)行版包管理器安裝:
sudo apt install tshark yum install wireshark
tshark使用很簡(jiǎn)單,直接用命令啟動(dòng)即可:
tshark和tcpdump一樣具有很強(qiáng)大的功能和各種過(guò)濾選項(xiàng),本文不在詳細(xì)介紹,此處列出兩個(gè)常用的例子供大家參考:
抓包http協(xié)議流:
tshark -s 512 -i eth0 -n -f 'tcp dst port 80' -R 'http.host and http.request.uri' -T fields -e http.host -e http.request.uri
解釋:
-s: 捕獲前512字節(jié)的信息; -i: 捕獲eth0網(wǎng)卡; -n: 不對(duì)網(wǎng)絡(luò)對(duì)象進(jìn)行轉(zhuǎn)義解釋; -f: 制定規(guī)則捕獲協(xié)議為tcp,目標(biāo)端口80; -R: 篩選http.host和http.request.uri字段; -e:打印這兩個(gè)字段;
捕捉數(shù)據(jù)庫(kù)服務(wù)器上的,sql查詢語(yǔ)句,可以用來(lái)做數(shù)據(jù)庫(kù)審計(jì):
tshark -s 512 -i eth0 -n -f 'tcp dst port 3306' -R 'mysql.query' -T fields -e mysql.query
解釋:
-R ‘mysql.query’:篩選出mysql.query字段 -T fields -e mysql.query :打印該字段
Nagios網(wǎng)絡(luò)監(jiān)控
Nagios是領(lǐng)先的開(kāi)源功能強(qiáng)大的監(jiān)控告警系統(tǒng),可讓網(wǎng)絡(luò)/系統(tǒng)管理員在影響主要業(yè)務(wù)流程之前識(shí)別和解決與服務(wù)器相關(guān)的問(wèn)題。使用Nagios系統(tǒng),管理員可以在一個(gè)窗口中監(jiān)視遠(yuǎn)程Linux,Windows,交換機(jī),路由器和打印機(jī)。根據(jù)設(shè)置的閾值,對(duì)超標(biāo)的主機(jī)和監(jiān)控項(xiàng)目進(jìn)行告警,然后針對(duì)具體問(wèn)題進(jìn)行排查。。
Nagios有一個(gè)Web界面,其中有活動(dòng)的圖形監(jiān)視器。界面 。如果在遠(yuǎn)程計(jì)算機(jī)上,請(qǐng)用您的IP地址替換localhost。然后輸入用戶名并通過(guò),然后,我們將看到如下所示的信息。
結(jié)論
本文蟲(chóng)蟲(chóng)給大家介紹了Linux在下的網(wǎng)絡(luò)監(jiān)控工具,每個(gè)工具都有其特定的功能和選項(xiàng),要了解網(wǎng)絡(luò)信息、系統(tǒng)配置和網(wǎng)絡(luò)鏈接情況可以使用Netstat和SS,要了解哪個(gè)進(jìn)程在消耗網(wǎng)絡(luò)帶寬,可以使用nethogs,而iftop可以顯示每個(gè)Socket連接的帶寬,nload等工具可以統(tǒng)計(jì)整體帶寬的使用情況,tcpdump、tcpflow和tshark可用來(lái)抓包分析。
文章題目:Linux下常用的網(wǎng)絡(luò)工具
文章鏈接:http://m.fisionsoft.com.cn/article/dpisdhh.html


咨詢
建站咨詢
