4 U) L7 K/ C9 o, A% ^. b3 d* L " H6 Y% b m5 R! j: l S. q; x' B
前言
$ N. o/ y% d3 Q2 G! V8 b0 r, j5 o
% t9 X' C, w! _) \4 U7 V5 F" E( G) \$ j
Linux常用命令中,有些命令可以用于查看系统的状态,通过了解系统当前的状态,能够帮助我们更好地维护系统或定位问题。本文就简单介绍一下这些命令。
! m1 Q1 v8 U, f& G3 b查看系统运行时间--uptime4 \+ r4 C7 h0 ]- G [9 y% u3 w% K
. g2 X- k; w$ s1 P' O! t5 b有时候我们想知道系统上一次复位是在什么时候或者系统已经运行了多长时间,我们可以通过uptime命令获取这些信息:; k) e. n1 r9 O0 a* Q/ v% P
uptime
9 L4 N" e+ A7 {1 C6 V20:47:06 up 50 min, 1 user, load average: 0.75, 0.84, 0.93
4 x7 `1 [0 C1 G; Y3 x, x* ?从左往右显示的信息依次为:当前时间、已运行时间、用户登录数、1分钟、5分钟和15分钟内系统的平均负载。( ]7 u- \3 l7 S" \+ j; _. Y
查看系统已登录用户--who
" v0 h5 N5 }1 c3 g7 O
# C8 ^. b' d) k! Twho -a4 S$ p" U& G; D7 Z( c& F* H1 r: z1 C
hyb tty7 2018-09-30 19:57 (:0)
6 w0 {, A& i5 C# C1 U" N2 N通过who命令可以查看到哪些用户通过哪个ip登录到了这台主机。
+ T$ [0 z9 w$ w* @* V查看系统版本相关信息--uname
! q( X6 S' p+ q0 E/ \# ]3 W: b2 j# v
例如:
! B, X0 U) i- ^% P0 A6 L$ i6 ]uname -a+ x) y) `; \9 y, D* [% U$ u8 N
Linux ubuntu16.04 4.15.0-34-generic #37~16.04.1-Ubuntu SMP Tue Aug 28 10:44:06 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux8 r/ p3 p* f* g: J' U9 c
从结果可以看到操作系统版本(ubuntu16.04),CPU类型(x86_64)等信息
4 Q) M, o5 `: a& {/ N7 V8 T查看当前环境变量--export6 s4 h* P; W- f W- v6 u
7 h6 n/ V2 x- |2 Q
环境变量影响着程序的运行,因此有时候需要查看当前环境的环境变量:# X' `- B' k( H7 @% W# N8 q" ^0 v: e
export
# X3 c* G* Z+ v. O. D! n查看目录和文件占用空间--du
$ O2 n l7 {- A; [+ R3 K. \* a$ A! G& b, ]/ I% o. A+ {
du命令直接显示当前目录下每个目录及其文件占用空间。结合--max-depth参数可以指定显示的目录层级。+ ?" ~7 l" I( y0 ?1 l3 {; C! N
例如,如果只想显示当前目录下各个目录所占总空间,可以使用:
# ^/ s6 U J, l9 D* j6 r. K$ `du -h --max-depth=1
6 @, Z" C l- I4 Q! [( c& y19M ./python
3 r4 r$ \( {* _: j9.0M ./git
3 ?" D! p$ |3 C U% d: V7 K321M ./hexo
8 q2 A, G) }* f6 |$ C, V: A- i17M ./lua3 V B8 y: N0 y' r' |5 _
28K ./vim
! s* Q/ c1 a8 Z2 D5 K# P. s9 a, q1.4M ./shell
* M. I$ m( [+ [, ]3 Z" {81M ./redis( Y, l$ g6 ^, h2 e1 V6 q
316M ./books
' e! p% {3 U+ W' t48M ./c& _7 W6 Q+ n. `3 J8 p0 k8 q
810M .
# H- t7 }6 `2 Q; g) A$ X( adu -sh #仅统计当前目录总大小
' ~6 d) K; ^* s; _6 G q; f810M
& `+ E2 b H n5 `, W6 C其中-h表示以易读的单位显示大小,即M,--max-depth=1表明目录层级。通过命令结果,我们可以看到当前目录下各个子目录占用空间大小,以及总空间大小。+ T2 Y" F# o( q3 A4 @: W
查看各挂载点空间--df6 Q: ?$ i( y2 I' L( _( M- E
8 H9 W$ }: w' a5 K& p
例如:
6 |! u7 _% q% r# ]! Odf -h
3 l, T) ]) [: I' Q+ n文件系统 容量 已用 可用 已用% 挂载点, W/ F: I/ K, L) s
udev 3.9G 0 3.9G 0% /dev! s5 e# Y" \4 p8 K7 P% j7 u& d
tmpfs 786M 9.5M 776M 2% /run+ m4 `. E8 t- {1 i, s+ F
/dev/sda10 24G 9.8G 13G 45% /( e/ S7 k& y' x4 L9 a! X9 L
tmpfs 3.9G 43M 3.8G 2% /dev/shm9 F" B* r+ e3 e' n" `4 F7 C- ^
tmpfs 5.0M 4.0K 5.0M 1% /run/lock+ Y: S8 P" u7 E. U
tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup
# `! p- p4 L* C/dev/sda11 454M 274M 153M 65% /boot
# V) j& B0 F/ w u/ N6 o1 N, m/dev/sda15 55G 5.2G 47G 10% /home3 k% G* z) n/ w6 Z6 g; l) s
/dev/sda1 256M 31M 226M 12% /boot/efi
: J8 X8 \0 J2 s1 h7 b2 I/dev/sda14 4.6G 9.9M 4.4G 1% /tmp
' I8 j# E. ]! \9 h8 p/ z) }- otmpfs 786M 60K 786M 1% /run/user/1000# t* p+ p' V' B5 j& `
从结果中,我们可以看到各个挂载点总空间以及可用空间。当磁盘文件占用空间较大时,可能导致系统运行缓慢,因此,可根据该结果进行相应的磁盘清理。
. M' V6 B5 T. w7 ^; e查看内存可用情况--free
0 r! C; V3 h S9 X! q4 r( K. G
. ^( S1 i/ i# _ U' |free命令可用于显示系统中可用的物理内存,交换区内存以及内核使用的buffer:4 j" |) [: D5 X; S/ G
free -h
/ J& P1 V: |) P total used free shared buff/cache available0 a, }% e+ M0 H$ j; \1 v: m8 f
Mem: 7.7G 2.3G 2.6G 268M 2.8G 4.7G) ~0 ]! o: b4 s* Z
Swap: 7.6G 0B 7.6G. K( _/ h$ p! u. d+ `
从执行结果可以看到已用内存和空闲内存的情况。同样地,当内存不足时,可能导致程序运行异常或系统卡顿。
$ H. B# f1 C& e3 f- M查看进程的内存使用情况--pmap
5 n& c. v# D$ E# w+ h9 d2 T
' o1 B5 G! e1 gpmap命令用于查看进程内存相关信息:0 i' z# q" {- T: \
pmap pid #pid为进程id,可通过ps命令获取
( V2 I' S r( {' _, Q6 _5 o6030: ./main) W# U* x; Y5 {# w
0000000000400000 4K r-x-- main
$ ?) F. W7 [7 p0000000000600000 4K r---- main9 D; V5 z ]! e/ n2 r8 r' N# N
0000000000601000 4K rw--- main; [1 q/ i- h' ^6 H
00000000017d2000 132K rw--- [ anon ]3 Q" @: B% s+ |. s. M1 j3 b+ Q
00007fc3843e8000 1792K r-x-- libc-2.23.so: U6 H2 f' b Z/ h$ @4 q" G
00007fc3845a8000 2048K ----- libc-2.23.so( c8 v1 V5 N! O$ _
00007fc3847a8000 16K r---- libc-2.23.so( j! t6 |1 @2 X. J
00007fc3847ac000 8K rw--- libc-2.23.so6 Q9 u X" M& P3 ]9 g- Q" L7 }6 a
00007fc3847ae000 16K rw--- [ anon ]
0 \) o( `* Y) H$ R- A; D4 m* o00007fc3847b2000 152K r-x-- ld-2.23.so! ]% B) T- E4 |6 h& o! H" W
00007fc3849b9000 12K rw--- [ anon ] j: \/ V' ` t7 S0 R# C
00007fc3849d7000 4K r---- ld-2.23.so
/ F! B, l/ j) Q, s# K00007fc3849d8000 4K rw--- ld-2.23.so) o+ x# ~7 h. ]; u
00007fc3849d9000 4K rw--- [ anon ]
% x- s8 h0 q, a; R1 ~00007ffcf2018000 132K rw--- [ stack ]6 @8 i5 K8 F# S! b
00007ffcf2175000 12K r---- [ anon ]0 U/ Y& {" U& j. x N
00007ffcf2178000 8K r-x-- [ anon ]3 P* V* L3 o6 G0 o5 p
ffffffffff600000 4K r-x-- [ anon ]
; g A- N- o# A. x! E total 4356K
* t. K7 Q9 a3 g5 u0 c我们可以根据进程各部分占用空间情况,来不断优化我们的程序。
+ u0 `: x7 a& L7 K查看虚拟内存统计信息--vmstat
! S$ B* a' T& E8 z$ l' t8 |. S( D$ f% b/ F# t* _6 E& L; g9 q7 }5 c
vmstat
7 u/ G S5 W& v% w; Y0 h k' ]procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----, L1 l5 I: \' x: V1 }
r b swpd free buff cache si so bi bo in cs us sy id wa st: x1 H- V e4 c. o. ^, c
1 0 0 2214960 407828 2572148 0 0 126 57 377 1006 8 2 88 2 0, a8 V3 T7 k; D, b( L- f( B
vmstat的输出值能够帮助我们了解当前系统的性能。比如说,如果si(每秒从交换区写到内存的大小)和so(每秒写入交换区的内存大小)的值经常大于0,说明内存可能不够用,因此才需要用到交换空间。再比如说,us(用户进程执行时间百分比)的值比较高时,说明用户进程消耗的CPU资源较多。而wa(IO等待时间百分比)值较高时,说明IO等待情况严重。
- a0 Q* [1 Y. _2 [/ G/ Q" k5 u查看ip地址--ip
# @ e$ ^. G" z+ d# B. u* A9 t U I+ M5 W
有时候使用ifconfig命令并不一定能够看到所有的ip地址,因此可以使用:
1 u% c& W9 ]. _ ~ip addr
4 u- z# H9 `3 r9 ]0 {; N查看网络连接状态--netstat
2 X" ^" h& n( Y' y3 E/ ~! z2 e1 n9 f! S7 h! ^+ h2 Z/ l4 R% |% U
netstat命令可以查看网络连接状态,通常用于诊断网络相关问题。例如查看端口是否被占用,连接是否已经释放,服务是否在监听等等。
" G0 K) h' Y& F4 y查看进程间关系--pstree
# f+ Y) q+ B" d8 O; h: i! {4 B9 w. i
3 I: j |0 N6 z* G, \* t6 V通过pstree命令可以看到进程间的父子关系,它以树形结构显示这些信息:
5 x3 I! ~$ h" |1 \( Ypstree& e$ O4 F2 M1 \+ h) U0 t! D
systemd─┬─ModemManager─┬─{gdbus}
9 E9 ?: Y5 @" b │ └─{gmain}! N' D1 y/ x& Y8 J2 h! e
├─NetworkManager─┬─dhclient# T3 z/ [2 M# w& ?" h2 g% S
│ ├─dnsmasq
9 Q7 X# z% m7 g- ` u- p, {* W( @7 a) m │ ├─{gdbus}, ^# f; Z" e5 E: Z) t e5 n" z! j9 z
│ └─{gmain}
+ b c7 @0 t2 ] I8 z5 [ ├─accounts-daemon─┬─{gdbus}
/ n7 o+ `; G- g+ z& R2 \ │ └─{gmain}( @' \0 T' A+ H$ A% a/ d9 p
├─acpid
: E. h+ f4 c( ~. I2 c1 A ├─atd
# ~4 N s: u, n" a4 P4 J1 O8 V ├─avahi-daemon───avahi-daemon
" D5 C; F: ]. \0 b ├─bluetoothd
& f% i8 |& @2 w) M" t ├─colord─┬─{gdbus}
# p. F% X: P( r! }4 H }( r# u │ └─{gmain}
9 y2 F& }# ^; B. l' d ├─cron
' E# |- B5 u( x3 M- i6 i ├─cups-browsed─┬─{gdbus}2 ~# k/ p# l4 n: Y& N' h9 V
│ └─{gmain}& n7 o+ t% ], L) ^9 p' L* o
├─cupsd───3*[dbus]' h9 I% T, `4 N3 K' X# Q
├─dbus-daemon( a; `+ W+ \9 z# M- I, ?
├─gnome-keyring-d─┬─{gdbus}# l6 f, I7 i1 N: m9 w" c+ T
│ ├─{gmain}8 U9 s& \0 m u7 n4 C( J
│ └─{timer}
5 g' h) Q5 I# c$ c(仅显示部分内容)
0 w! ^/ N+ ~) g6 ^3 I总结
) @$ U6 |; q3 d( b0 Y
) u; V- ?3 |4 X! R实际上,前面所提到的很多相关命令信息都是从系统文件中获取的,例如/proc/meminfo保存了内存相关信息,/proc/net/dev保存网络流量相关信息。只是,它们都是静态数值,但是我们可以结合watch命令来动态地观察这些信息,例如:. `8 P8 u" f0 |, g" R( q l" x; m
watch -n 1 cat /proc/meminfo
! W7 p3 |" L, V/ |( u) j9 F
2 y+ F% B* v, M3 b% Wwatch -n 1 cat /proc/net/dev7 q; P1 Y0 a; e5 h5 l1 b6 {1 v* C
上面的命令表示,每隔一秒执行一次cat /proc/meminfo或cat /proc/net/dev,因此我们可以看到内存信息或网卡流量信息在实时刷新。# b" Y h) y# Z" m+ H# y; R; `* R/ x. w
本文仅介绍这些命令的经典使用,更多使用可通过man 命令查看。通过前面这些系统自带命令,我们可以比较方便地监控系统状态,从而帮助我们维护系统或定位问题。欢迎留言补充或更正。
|