1、uptime
[root@smgsim02 ~]# uptime
15:08:15 up 98 days, 4:19, 2 users, load average: 0.07, 0.29, 0.14
當前時間 系統運行至今的時間 多少使用者登錄當前系統 分別是1分鐘, 5分鐘, 15分鐘前至今的負載情況
load average是佇列平均長度, 在佇列中等待執行的進程數量
該值越低, 說明進程更有可能立即被CPU處理, 相反越高, 說明進程更有可能阻塞
該命令可以檢查伺服器負載是否高。
2、top
TOP命令更多使用示例, 可以閱讀:top命令在Linux上的12個使用案例
顯示CPU實際使用情況
top的第一行就是uptime命令的內容
第二行:進程資訊
Tasks: 71 total 進程總數
2 running 正在運行的進程數
69 sleeping 睡眠的進程數
0 stopped 停止的進程數
0 zombie 僵屍進程數
第三行:CPU信息
Cpu(s): 4.8%us 用戶空間佔用CPU百分比
6.9%sy 內核空間佔用CPU百分比
0.0%ni 使用者進程空間內改變過優先順序的進程佔用CPU百分比
87.2%id 空閒CPU百分比
0.0%wa 等待輸入輸出的CPU時間百分比
1.1% hi
0.0% si
第四行:實體記憶體信息
Mem: 255102k total 實體記憶體總量
253572k used 使用的實體記憶體總量
1548k free 空閒記憶體總量
13576k buffers 用作內核緩存的記憶體量
第五行:交換區資訊
Swap: 522104k total 交換區總量
9892k used 使用的交換區總量
512212k free 空閒交換區總量
34120k cached 緩衝的交換區總量。
記憶體中的內容被換出到交換區, 而後又被換入到記憶體, 但使用過的交換區尚未被覆蓋, 該數值即為這些內容已存在於記憶體中的交換區的大小。 相應的記憶體再次被換出時可不必再對交換區寫入。
進程資訊區:
統計資訊區域的下方顯示了各個進程的詳細資訊。 首先來認識一下各列的含義。
序號 列名 含義
PID 進程id
PPID 父進程id
RUSER Real user name
UID 進程所有者的使用者id
USER 進程所有者的用戶名
GROUP 進程所有者的組名
TTY 啟動進程的終端名。 不是從終端啟動的進程則顯示為 ?
PR 優先順序
NI nice值,負值表示高優先順序, 正值表示低優先順序
P 最後使用的CPU, 僅在多CPU環境下有意義
VIRT:進程使用的虛擬記憶體的總量, 單位kb, VIRT=SWAP+RES
RES: 進程使用的未被換出的實體記憶體的大小, 單位kb, 亦稱常駐記憶體, RES=CODE+DATA
SHR:共用記憶體大小, 單位kb, 即該進程和其他進程共用記憶體的數量
%MEM:進程使用的實體記憶體百分比
TIME+:進程使用的cpu時間總計, 單位1/100s
COMMAND:命令名稱/行
%CPU 上次更新到現在的CPU時間佔用百分比
SWAP:進程使用的虛擬記憶體中, 未被換出的大小(kb)
CODE:可執行代碼佔用的實體記憶體的大小
DATA: 可執行代碼以外的部分(資料段+棧)佔用的實體記憶體大小(kb)
nFLT 分頁錯誤次數
nDRT 最後一次寫入到現在, 被修改過的頁面數。
STAT:進程的狀態:S=休眠狀態, R=運行狀態, T=停止狀態, D=中斷休眠狀態, Z=僵屍狀態
WCHAN 若該進程在睡眠, 則顯示睡眠中的系統函數名
Flags 任務標誌, 參考 sched.h
SIZE:進程佔用的記憶體數量(代碼+資料+堆疊)
RSS;進程使用的實體記憶體數量
Badness=oom_score(bandness)
Adj=oom_adjustment
輸入完top命令後, 可繼續按下f鍵, 選擇需要添加的顯示列
通過 f 鍵可以選擇顯示的內容。 按 f 鍵之後會顯示列的清單, 按 a-z 即可顯示或隱藏對應的列, 最後按回車鍵確定。
按 o 鍵可以改變列的顯示順序。 按小寫的 a-z 可以將相應的列向右移動, 而大寫的 A-Z 可以將相應的列向左移動。 最後按回車鍵確定。
按大寫的 F 或 O 鍵, 然後按 a-z 可以將進程按照相應的列進行排序。
top命令參數解釋:
top [-] [d] [p] [q] [c] [C] [S] [s] [n]
d 指定每兩次螢幕資訊刷新之間的時間間隔。 當然用戶可以使用s交互命令來改變之。
p 通過指定監控進程ID來僅僅監控某個進程的狀態。
q該選項將使top沒有任何延遲的進行刷新。 如果調用程式有超級使用者許可權, 那麼top將以盡可能高的優先順序運行。
S 指定累計模式
s 使top命令在安全模式中運行。 這將去除交互命令所帶來的潛在危險。
i 使top不顯示任何閒置或者僵死進程。
c 顯示整個命令列而不只是顯示命令名
下面介紹在top命令執行過程中可以使用的一些交互命令。 從使用角度來看, 熟練的掌握這些命令比掌握選項還重要一些。 這些命令都是單字母的,
Ctrl+L 擦除並且重寫螢幕。
h或者? 顯示説明畫面, 給出一些簡短的命令總結說明。
k 終止一個進程。 系統將提示使用者輸入需要終止的進程PID, 以及需要發送給該進程什麼樣的信號。 一般的終止進程可以使用15信號;如果不能正常結束那就使用信號9強制結束該進程。 預設值是信號15。 在安全模式中此命令被遮罩。
i 忽略閒置和僵死進程。 這是一個開關式命令。
q 退出程式。
r 重新安排一個進程的優先順序別。 系統提示使用者輸入需要改變的進程PID以及需要設置的進程優先順序值。 輸入一個正值將使優先順序降低, 反之則可以使該進程擁有更高的優先權。 預設值是10。
S 切換到累計模式。
s 改變兩次刷新之間的延遲時間。系統將提示使用者輸入新的時間,單位為s。如果有小數,就換算成m s。輸入0值則系統將不斷刷新,預設值是5 s。需要注意的是如果設置太小的時間,很可能會引起不斷刷新,從而根本來不及看清顯示的情況,而且系統負載也會大大增加。
f或者F 從當前顯示中添加或者刪除專案。
o或者O 改變顯示專案的順序。
l 切換顯示平均負載和啟動時間資訊。
m 切換顯示記憶體資訊。
t 切換顯示進程和CPU狀態資訊。
c 切換顯示命令名稱和完整命令列。
M 根據駐留記憶體大小進行排序。
P 根據CPU使用百分比大小進行排序。
T 根據時間/累計時間進行排序。
W 將當前設置寫入~/.toprc文件中。這是寫top設定檔的推薦方法。
僵屍進程
當一個進程被結束,在它結束之前通常需要用一些時間去完成所有的任務(比如關閉打開的檔),在一個很短的時間裡,這個進程的狀態為僵屍狀態。在進程完成所有關閉任務之後,會向父進程提交它關閉的資訊。有些情況下,一個僵屍進程不能關閉它自己,這時這個進程狀態就為z(zombie)。不能使用kill命令殺死僵屍進程,因為它已經標誌為“dead”。如果你無法擺脫一個僵屍進程,你可以殺死它的父進程,這個僵屍進程也就消失了。然而,如果父進程是init進程,你不能殺死init進程,因為init是一個重要的系統進程,這種情況下你只能通過一次重新開機伺服器來擺脫僵屍進程。也必須分析應用為什麼會導致僵死?
第二行tasks可以看到系統中僵屍進程的數量
3、iostat
更多iostat使用示例和說明,閱讀:iostat命令在Linux上的6個使用案例
avg-cpu:
%user:user level(應用)的CPU佔用率情況
%nice:加入nice優先順序的user level的CPU佔用率情況
%sys:system level(內核)的CPU佔用情況
%idle:空閒的CPU資源情況
磁片資訊
Device:塊設備名
Tps:設備每秒進行傳輸的數量(每秒的I/O請求)。多個單獨的I/O請求可以被組成一個傳輸操作,因為一個傳輸操作可以是不同的容量。
Blk_read/s, Blk_wrtn/s:該設備每秒讀寫的塊的數量。塊可能為不同的容量。
Blk_read, Blk_wrtn:自系統啟動以來讀寫的塊設備的總量。
4、vmstat
關於vmstat命令更多使用示例,請閱讀:vmstat在Linux中的6個使用案例
Vmstat命令提供了對進程、記憶體、頁面I/O塊和CPU等資訊的監控,vmstat可以顯示檢測結果的平均值或者取樣值,取樣模式可以提供一個取樣時間段內不同頻率的監測結果
·process(procs)
r:等待執行時間的進程數量
b:處在不可中斷睡眠狀態的進程
w:被交換出去但是仍然可以運行的進程,這個值是計算出來的
·memoryswpd:虛擬記憶體的數量
free:空閒記憶體的數量
buff:用做緩衝區的記憶體數量
·swap
si:從硬碟交換來的數量
so:交換到硬碟去的數量
·IO
bi:向一個塊設備輸出的塊數量
bo:從一個塊設備接受的塊數量
·system
in:每秒發生的中斷數量, 包括時鐘
cs:每秒發生的context switches的數量
·cpu(整個cpu執行時間的百分比)
us:非內核代碼運行的時間(用戶時間,包括nice時間)
sy:內核代碼運行的時間(系統時間)
id:閒置時間
wa:等待I/O操作的時間
·m:顯示內核的記憶體利用率
·a:顯示記憶體頁面資訊,包括活躍和不活躍的記憶體頁面
·n:顯示報頭行,這個參數在使用取樣模式並將命令結果輸出到一個檔時非常有用。例如root#vmstat –n 2 10以2秒的頻率顯示10輸出結果
5、ps和pstree
分析進程的好命令啊!
6、sar
自動收集保存系統資訊,crontab配置系統定時任務
crontab命令格式含義:分鐘(0-59) 小時(0-23) 日期(1-31) 月份(1-12) 星期(0-6) 命令段
下面看看看幾個具體的例子:
● 0 */2 * * * /sbin/service httpd restart 意思是每兩個小時重啟一次apache
● 50 7 * * * /sbin/service sshd start 意思是每天7:50開啟ssh服務
● 50 22 * * * /sbin/service sshd stop 意思是每天22:50關閉ssh服務
● 0 0 1,15 * * fsck /home 每月1號和15號檢查/home 磁片
● 1 * * * * /home/bruce/backup 每小時的第一分執行 /home/bruce/backup這個檔
● 00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} ; 每週一至週五3點鐘,在目錄/home中,查找檔案名為*.xxx的檔,並刪除4天前的檔。
● 30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30執行一次ls命令
7、free
顯示系統記憶體資訊
·-b,-k,-m和-g分別按照bytes, kilobytes, megabytes, gigabytes顯示結果。
·-l區別顯示low和high記憶體
·-c {count}顯示free輸出的次數
8、pmap
pmap pid查看具體進程的記憶體使用情況
查看進程的記憶體映射資訊(report memory map of a process) # pmap 用法 pmap [options] PID [PID ...] 選項 Options: -x, --extended show details //顯示擴展格式 -X show even more details WARNING: format changes according to /proc/PID/smaps -XX show everything the kernel provides -c, --read-rc read the default rc -C, --read-rc-from= read the rc from file -n, --create-rc create new default rc -N, --create-rc-to= create new rc to file NOTE: pid arguments are not allowed with -n, -N -d, --device show the device format //顯示裝置格式 -q, --quiet do not display header and footer //不顯示頭尾行 -p, --show-path show path in the mapping -A, --range=[,] limit results to the given range
-h, --help display this help and exit -V, --version output version information and exit //顯示版本
擴展格式和設備格式域: Address: start address of map 映射起始位址 Kbytes: size of map in kilobytes 映射大小(KB) RSS: resident set size in kilobytes 駐留集大小(保留記憶體大小)(KB) Dirty: dirty pages (both shared and private) in kilobytes 髒頁大小(KB) Mode: permissions on map 映射許可權: r=read, w=write, x=execute, s=shared, p=private (copy on write) Mapping: file backing the map , or '[ anon ]' for allocated memory, or '[ stack ]' for the program stack. 佔用記憶體的檔,[anon]為已分配記憶體,[stack]為程式堆疊 Offset: offset into the file 文件偏移 Device: device name (major:minor) 設備名
# pmap -x 5002 5002: /opt/jvm/java8/bin/java -Dorg.mortbay.util.URI.charset=UTF-8 -Xmx6008331k -Xms6008331k -XX:MaxPermSize=512m -Djava.library.path=/opt/app/../libswt/linux/x86_64/ ...... e.enc Address Kbytes RSS Dirty Mode Mapping 0000000000400000 4 4 0 r-x-- java 0000000000600000 4 4 4 rw--- java 000000000120d000 132 24 24 rw--- [ anon ] 0000000651400000 6015488 573320 573320 rw--- [ anon ] ...... ...... 00007fffa449f000 132 44 44 rw--- [ stack ] 00007fffa45fe000 8 4 0 r-x-- [ anon ] ffffffffff600000 4 0 0 r-x-- [ anon ] ---------------- ------- ------- ------- total kB 12052840 856168 806504
# pmap -d pid 5002: /opt/jvm/java8/bin/java -Dorg.mortbay.util.URI.charset=UTF-8 -Xmx6008331k -Xms6008331k -XX:MaxPermSize=512m -Djava.library.path=/opt/app/../libswt/linux/x86_64/ ...... Address Kbytes Mode Offset Device Mapping 0000000000400000 4 r-x-- 0000000000000000 0fd:00000 java 0000000000600000 4 rw--- 0000000000000000 0fd:00000 java 000000000120d000 132 rw--- 0000000000000000 000:00000 [ anon ] ...... ...... 00007fffa449f000 132 rw--- 0000000000000000 000:00000 [ stack ] 00007fffa45fe000 8 r-x-- 0000000000000000 000:00000 [ anon ] ffffffffff600000 4 r-x-- 0000000000000000 000:00000 [ anon ] mapped: 12014504K writeable/private: 6589148K shared: 38336K
最後一行的值 mapped:表示該進程映射的虛擬位址空間大小,也就是該進程預先分配的虛擬記憶體大小,即ps出的vsz writeable/private:表示進程所佔用的私有位址空間大小,也就是該進程實際使用的記憶體大小 shared:表示進程和其他進程共用的記憶體大小
只顯示最後一行: # pmap -d 5002 | tail -1 mapped: 12014504K writeable/private: 6589148K shared: 38336K
迴圈顯示最後一行,試試監控進程記憶體佔用情況: # while true; do pmap -d 5002 | tail -1; sleep 3; done
9、LSOF——列出打開的文件
更多lsof使用說明請閱讀:lsof命令在Linux中的10個使用案例
lsof命令和許多Linux/Unix系統命令一樣,用於顯示所有打開檔和進程。這些打開檔包括磁片檔、網路通訊端、管道、設備和進程。使用它最主要的原因是在卸載檔案系統時,如果該檔案系統中有任何打開的檔,操作通常將會失敗,那麼通過lsof可以找出哪些進程在使用,此命令最常用的格式如下:
10、TCPDUMP——網路資料包分析器
tcpdump是使用最廣泛的命令列——網路資料包分析器或資料包嗅探器程式,用來捕獲或過濾從網路特定介面接收到或者轉移的TCP/IP資料包。它還把捕獲到的包保存到一個資料夾中。tcpdump可以在所有主要的Linux發行版本上使用。
更多tcpdump使用案例,請閱讀:tcpdump命令在Linux系統中的12個使用案例
11、NETSTAT——網路統計
netstat是一個命令列工具,用於監視傳入和傳出的網路資料包資訊和介面資訊統計。系統管理員使用它進行監控網路性能和對網路相關問題進行故障排除是非常有用的。
12、HTOP——Linux進程監測
Htop是一個更先進的交互性和即時性的Linux進程監控工具。這個命令與top命令非常相似,但它的功能更加豐富,如友好的使用者介面進程管理、快速鍵、垂直和水準視圖進程等。Htop是一個協力廠商外掛程式工具,你需要使用YUM套裝軟體管理工具在Linux系統上安裝才可以使用。
HTOP安裝說明:在Linux中安裝HTOP(Linux進程監測)
13、lotop——監控Linux磁片I/O
Lotop與top命令和Htop程式很相似,但它具有統計功能,即時監測和顯示磁片I/O。這個工具對精確進程和發現高使用量的讀/寫進程非常有用的。
Loptop安裝使用說明:在Linux中安裝loptop
14、磁片使用
df -h
15、查看記憶體資訊
# cat /proc/meminfo
16、查看當前作業系統內核資訊
# uname -a
17、查看當前作業系統發行版本資訊
# cat /etc/issue | grep Linux
18、查看機器型號
# dmidecode | grep "Product Name"
19、查看網卡資訊
# dmesg | grep -i eth
20、查看linux版本
lsb_release -a <
s 改變兩次刷新之間的延遲時間。系統將提示使用者輸入新的時間,單位為s。如果有小數,就換算成m s。輸入0值則系統將不斷刷新,預設值是5 s。需要注意的是如果設置太小的時間,很可能會引起不斷刷新,從而根本來不及看清顯示的情況,而且系統負載也會大大增加。
f或者F 從當前顯示中添加或者刪除專案。
o或者O 改變顯示專案的順序。
l 切換顯示平均負載和啟動時間資訊。
m 切換顯示記憶體資訊。
t 切換顯示進程和CPU狀態資訊。
c 切換顯示命令名稱和完整命令列。
M 根據駐留記憶體大小進行排序。
P 根據CPU使用百分比大小進行排序。
T 根據時間/累計時間進行排序。
W 將當前設置寫入~/.toprc文件中。這是寫top設定檔的推薦方法。
僵屍進程
當一個進程被結束,在它結束之前通常需要用一些時間去完成所有的任務(比如關閉打開的檔),在一個很短的時間裡,這個進程的狀態為僵屍狀態。在進程完成所有關閉任務之後,會向父進程提交它關閉的資訊。有些情況下,一個僵屍進程不能關閉它自己,這時這個進程狀態就為z(zombie)。不能使用kill命令殺死僵屍進程,因為它已經標誌為“dead”。如果你無法擺脫一個僵屍進程,你可以殺死它的父進程,這個僵屍進程也就消失了。然而,如果父進程是init進程,你不能殺死init進程,因為init是一個重要的系統進程,這種情況下你只能通過一次重新開機伺服器來擺脫僵屍進程。也必須分析應用為什麼會導致僵死?
第二行tasks可以看到系統中僵屍進程的數量
3、iostat
更多iostat使用示例和說明,閱讀:iostat命令在Linux上的6個使用案例
avg-cpu:
%user:user level(應用)的CPU佔用率情況
%nice:加入nice優先順序的user level的CPU佔用率情況
%sys:system level(內核)的CPU佔用情況
%idle:空閒的CPU資源情況
磁片資訊
Device:塊設備名
Tps:設備每秒進行傳輸的數量(每秒的I/O請求)。多個單獨的I/O請求可以被組成一個傳輸操作,因為一個傳輸操作可以是不同的容量。
Blk_read/s, Blk_wrtn/s:該設備每秒讀寫的塊的數量。塊可能為不同的容量。
Blk_read, Blk_wrtn:自系統啟動以來讀寫的塊設備的總量。
4、vmstat
關於vmstat命令更多使用示例,請閱讀:vmstat在Linux中的6個使用案例
Vmstat命令提供了對進程、記憶體、頁面I/O塊和CPU等資訊的監控,vmstat可以顯示檢測結果的平均值或者取樣值,取樣模式可以提供一個取樣時間段內不同頻率的監測結果
·process(procs)
r:等待執行時間的進程數量
b:處在不可中斷睡眠狀態的進程
w:被交換出去但是仍然可以運行的進程,這個值是計算出來的
·memoryswpd:虛擬記憶體的數量
free:空閒記憶體的數量
buff:用做緩衝區的記憶體數量
·swap
si:從硬碟交換來的數量
so:交換到硬碟去的數量
·IO
bi:向一個塊設備輸出的塊數量
bo:從一個塊設備接受的塊數量
·system
in:每秒發生的中斷數量, 包括時鐘
cs:每秒發生的context switches的數量
·cpu(整個cpu執行時間的百分比)
us:非內核代碼運行的時間(用戶時間,包括nice時間)
sy:內核代碼運行的時間(系統時間)
id:閒置時間
wa:等待I/O操作的時間
·m:顯示內核的記憶體利用率
·a:顯示記憶體頁面資訊,包括活躍和不活躍的記憶體頁面
·n:顯示報頭行,這個參數在使用取樣模式並將命令結果輸出到一個檔時非常有用。例如root#vmstat –n 2 10以2秒的頻率顯示10輸出結果
5、ps和pstree
分析進程的好命令啊!
6、sar
自動收集保存系統資訊,crontab配置系統定時任務
crontab命令格式含義:分鐘(0-59) 小時(0-23) 日期(1-31) 月份(1-12) 星期(0-6) 命令段
下面看看看幾個具體的例子:
● 0 */2 * * * /sbin/service httpd restart 意思是每兩個小時重啟一次apache
● 50 7 * * * /sbin/service sshd start 意思是每天7:50開啟ssh服務
● 50 22 * * * /sbin/service sshd stop 意思是每天22:50關閉ssh服務
● 0 0 1,15 * * fsck /home 每月1號和15號檢查/home 磁片
● 1 * * * * /home/bruce/backup 每小時的第一分執行 /home/bruce/backup這個檔
● 00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} ; 每週一至週五3點鐘,在目錄/home中,查找檔案名為*.xxx的檔,並刪除4天前的檔。
● 30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30執行一次ls命令
7、free
顯示系統記憶體資訊
·-b,-k,-m和-g分別按照bytes, kilobytes, megabytes, gigabytes顯示結果。
·-l區別顯示low和high記憶體
·-c {count}顯示free輸出的次數
8、pmap
pmap pid查看具體進程的記憶體使用情況
查看進程的記憶體映射資訊(report memory map of a process) # pmap 用法 pmap [options] PID [PID ...] 選項 Options: -x, --extended show details //顯示擴展格式 -X show even more details WARNING: format changes according to /proc/PID/smaps -XX show everything the kernel provides -c, --read-rc read the default rc -C, --read-rc-from= read the rc from file -n, --create-rc create new default rc -N, --create-rc-to= create new rc to file NOTE: pid arguments are not allowed with -n, -N -d, --device show the device format //顯示裝置格式 -q, --quiet do not display header and footer //不顯示頭尾行 -p, --show-path show path in the mapping -A, --range=[,] limit results to the given range
-h, --help display this help and exit -V, --version output version information and exit //顯示版本
擴展格式和設備格式域: Address: start address of map 映射起始位址 Kbytes: size of map in kilobytes 映射大小(KB) RSS: resident set size in kilobytes 駐留集大小(保留記憶體大小)(KB) Dirty: dirty pages (both shared and private) in kilobytes 髒頁大小(KB) Mode: permissions on map 映射許可權: r=read, w=write, x=execute, s=shared, p=private (copy on write) Mapping: file backing the map , or '[ anon ]' for allocated memory, or '[ stack ]' for the program stack. 佔用記憶體的檔,[anon]為已分配記憶體,[stack]為程式堆疊 Offset: offset into the file 文件偏移 Device: device name (major:minor) 設備名
# pmap -x 5002 5002: /opt/jvm/java8/bin/java -Dorg.mortbay.util.URI.charset=UTF-8 -Xmx6008331k -Xms6008331k -XX:MaxPermSize=512m -Djava.library.path=/opt/app/../libswt/linux/x86_64/ ...... e.enc Address Kbytes RSS Dirty Mode Mapping 0000000000400000 4 4 0 r-x-- java 0000000000600000 4 4 4 rw--- java 000000000120d000 132 24 24 rw--- [ anon ] 0000000651400000 6015488 573320 573320 rw--- [ anon ] ...... ...... 00007fffa449f000 132 44 44 rw--- [ stack ] 00007fffa45fe000 8 4 0 r-x-- [ anon ] ffffffffff600000 4 0 0 r-x-- [ anon ] ---------------- ------- ------- ------- total kB 12052840 856168 806504
# pmap -d pid 5002: /opt/jvm/java8/bin/java -Dorg.mortbay.util.URI.charset=UTF-8 -Xmx6008331k -Xms6008331k -XX:MaxPermSize=512m -Djava.library.path=/opt/app/../libswt/linux/x86_64/ ...... Address Kbytes Mode Offset Device Mapping 0000000000400000 4 r-x-- 0000000000000000 0fd:00000 java 0000000000600000 4 rw--- 0000000000000000 0fd:00000 java 000000000120d000 132 rw--- 0000000000000000 000:00000 [ anon ] ...... ...... 00007fffa449f000 132 rw--- 0000000000000000 000:00000 [ stack ] 00007fffa45fe000 8 r-x-- 0000000000000000 000:00000 [ anon ] ffffffffff600000 4 r-x-- 0000000000000000 000:00000 [ anon ] mapped: 12014504K writeable/private: 6589148K shared: 38336K
最後一行的值 mapped:表示該進程映射的虛擬位址空間大小,也就是該進程預先分配的虛擬記憶體大小,即ps出的vsz writeable/private:表示進程所佔用的私有位址空間大小,也就是該進程實際使用的記憶體大小 shared:表示進程和其他進程共用的記憶體大小
只顯示最後一行: # pmap -d 5002 | tail -1 mapped: 12014504K writeable/private: 6589148K shared: 38336K
迴圈顯示最後一行,試試監控進程記憶體佔用情況: # while true; do pmap -d 5002 | tail -1; sleep 3; done
9、LSOF——列出打開的文件
更多lsof使用說明請閱讀:lsof命令在Linux中的10個使用案例
lsof命令和許多Linux/Unix系統命令一樣,用於顯示所有打開檔和進程。這些打開檔包括磁片檔、網路通訊端、管道、設備和進程。使用它最主要的原因是在卸載檔案系統時,如果該檔案系統中有任何打開的檔,操作通常將會失敗,那麼通過lsof可以找出哪些進程在使用,此命令最常用的格式如下:
10、TCPDUMP——網路資料包分析器
tcpdump是使用最廣泛的命令列——網路資料包分析器或資料包嗅探器程式,用來捕獲或過濾從網路特定介面接收到或者轉移的TCP/IP資料包。它還把捕獲到的包保存到一個資料夾中。tcpdump可以在所有主要的Linux發行版本上使用。
更多tcpdump使用案例,請閱讀:tcpdump命令在Linux系統中的12個使用案例
11、NETSTAT——網路統計
netstat是一個命令列工具,用於監視傳入和傳出的網路資料包資訊和介面資訊統計。系統管理員使用它進行監控網路性能和對網路相關問題進行故障排除是非常有用的。
12、HTOP——Linux進程監測
Htop是一個更先進的交互性和即時性的Linux進程監控工具。這個命令與top命令非常相似,但它的功能更加豐富,如友好的使用者介面進程管理、快速鍵、垂直和水準視圖進程等。Htop是一個協力廠商外掛程式工具,你需要使用YUM套裝軟體管理工具在Linux系統上安裝才可以使用。
HTOP安裝說明:在Linux中安裝HTOP(Linux進程監測)
13、lotop——監控Linux磁片I/O
Lotop與top命令和Htop程式很相似,但它具有統計功能,即時監測和顯示磁片I/O。這個工具對精確進程和發現高使用量的讀/寫進程非常有用的。
Loptop安裝使用說明:在Linux中安裝loptop
14、磁片使用
df -h
15、查看記憶體資訊
# cat /proc/meminfo
16、查看當前作業系統內核資訊
# uname -a
17、查看當前作業系統發行版本資訊
# cat /etc/issue | grep Linux
18、查看機器型號
# dmidecode | grep "Product Name"
19、查看網卡資訊
# dmesg | grep -i eth
20、查看linux版本
lsb_release -a <