序言
Linux常用命令中,有些命令可以用于查看系统的状态,通过了解系统当前的状态,就能帮助我们更好地维护系统或定位问题。本文就简单介绍一下那些命令。
查看系统运行时间--uptime
有时侯我们想晓得系统上一次复位是在哪些时侯或则系统早已运行了多长时间linux查看桌面环境变量,我们可以通过uptime命令获取这种信息:
uptime
20:47:06 up 50 min, 1 user, load average: 0.75, 0.84, 0.93
从左向右显示的信息依次为:当前时间、已运行时间、用户登陆数、1分钟、5分钟和15分钟内系统的平均负载。
查看系统已登入用户--who
who -a
hyb tty7 2018-09-30 19:57 (:0)
通过who命令可以查看到什么用户通过那个ip登陆到了这台主机。
查看系统版本相关信息--uname
比如:
uname -a
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/Linux
从结果可以看见操作系统版本(ubuntu16.04),CPU类型(x86_64)等信息
查看当前环境变量--export
环境变量影响着程序的运行,因而有时侯须要查看当前环境的环境变量:
export
查看目录和文件占用空间--du
du命令直接显示当前目录下每位目录及其文件占用空间。结合--max-depth参数可以指定显示的目录层级。
比如,假若只想显示当前目录下各个目录所占总空间,可以使用:
du -h --max-depth=1
19M ./python
9.0M ./git
321M ./hexo
17M ./lua
28K ./vim
1.4M ./shell
81M ./redis
316M ./books
48M ./c
810M .
du -sh #仅统计当前目录总大小
810M
其中-h表示以易读的单位显示大小,即M,--max-depth=1表明目录层级。通过命令结果,我们可以看见当前目录下各个子目录占用空间大小,以及总空间大小。
查看各挂载点空间--df
比如:
df -h
文件系统 容量 已用 可用 已用% 挂载点
udev 3.9G 0 3.9G 0% /dev
tmpfs 786M 9.5M 776M 2% /run
/dev/sda10 24G 9.8G 13G 45% /
tmpfs 3.9G 43M 3.8G 2% /dev/shm
tmpfs 5.0M 4.0K 5.0M 1% /run/lock
tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup
/dev/sda11 454M 274M 153M 65% /boot
/dev/sda15 55G 5.2G 47G 10% /home
/dev/sda1 256M 31M 226M 12% /boot/efi
/dev/sda14 4.6G 9.9M 4.4G 1% /tmp
tmpfs 786M 60K 786M 1% /run/user/1000
从结果中,我们可以见到各个挂载点总空间以及可用空间。当c盘文件占用空间较大时,可能造成系统运行平缓,为此,可依照该结果进行相应的c盘清除。
查看显存可用情况--free
free命令可用于显示系统中可用的化学显存,交换区显存以及内核使用的buffer:
free -h
total used free shared buff/cache available
Mem: 7.7G 2.3G 2.6G 268M 2.8G 4.7G
Swap: 7.6G 0B 7.6G
从执行结果可以看见已用显存和空闲显存的情况。同样地,当显存不足时,可能造成程序运行异常或系统卡顿。
查看进程的显存使用情况--pmap
pmap命令用于查看进程显存相关信息:
pmap pid #pid为进程id,可通过ps命令获取
6030: ./main
0000000000400000 4K r-x-- main
0000000000600000 4K r---- main
0000000000601000 4K rw--- main
00000000017d2000 132K rw--- [ anon ]
00007fc3843e8000 1792K r-x-- libc-2.23.so
00007fc3845a8000 2048K ----- libc-2.23.so
00007fc3847a8000 16K r---- libc-2.23.so
00007fc3847ac000 8K rw--- libc-2.23.so
00007fc3847ae000 16K rw--- [ anon ]
00007fc3847b2000 152K r-x-- ld-2.23.so
00007fc3849b9000 12K rw--- [ anon ]
00007fc3849d7000 4K r---- ld-2.23.so
00007fc3849d8000 4K rw--- ld-2.23.so
00007fc3849d9000 4K rw--- [ anon ]
00007ffcf2018000 132K rw--- [ stack ]
00007ffcf2175000 12K r---- [ anon ]
00007ffcf2178000 8K r-x-- [ anon ]
ffffffffff600000 4K r-x-- [ anon ]
total 4356K
我们可以按照进程各部份占用空间情况,来不断优化我们的程序。
查看虚拟显存统计信息--vmstat
vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
r b swpd free buff cache si so bi bo in cs us sy id wa st
1 0 0 2214960 407828 2572148 0 0 126 57 377 1006 8 2 88 2 0
vmstat的输出值才能帮助我们了解当前系统的性能。例如说,假如si(每秒从交换区讲到显存的大小)和so(每秒写入交换区的显存大小)的值常常小于0,说明显存可能不够用,因而才须要用到交换空间。再例如说,us(用户进程执行时间比率)的值比较高时,说明用户进程消耗的CPU资源较多。而wa(IO等待时间比率)值较高时,说明IO等待情况严重。
查看ip地址--ip
有时侯使用ifconfig命令并不一定就能看见所有的ip地址,因而可以使用:
ip addr
查看网路联接状态--netstat
netstat命令可以查看网路联接状态,一般用于确诊网路相关问题。诸如查看端口是否被占用,联接是否早已释放,服务是否在窃听等等。
查看进程间关系--pstree
通过pstree命令可以看见进程间的兄妹关系,它以树状结构显示这种信息:
pstree
systemd─┬─ModemManager─┬─{gdbus}
│ └─{gmain}
├─NetworkManager─┬─dhclient
│ ├─dnsmasq
│ ├─{gdbus}
│ └─{gmain}
├─accounts-daemon─┬─{gdbus}
│ └─{gmain}
├─acpid
├─atd
├─avahi-daemon───avahi-daemon
├─bluetoothd
├─colord─┬─{gdbus}
│ └─{gmain}
├─cron
├─cups-browsed─┬─{gdbus}
│ └─{gmain}
├─cupsd───3*[dbus]
├─dbus-daemon
├─gnome-keyring-d─┬─{gdbus}
│ ├─{gmain}
│ └─{timer}
(仅显示部分内容)
总结
实际上,上面所提及的好多相关命令信息都是从系统文件中获取的,比如/proc/meminfo保存了显存相关信息red hat linux 下载,/proc/net/dev保存网路流量相关信息。只是,它们都是静态数值linux查看桌面环境变量,而且我们可以结合watch命令来动态地观察那些信息linux服务器搭建,比如:
watch -n 1 cat /proc/meminfo
watch -n 1 cat /proc/net/dev
里面的命令表示,每隔1秒执行一次cat/proc/meminfo或cat/proc/net/dev,因而我们可以看见显存信息或网卡流量信息在实时刷新。
本文仅介绍这种命令的精典使用,更多使用可通过man命令查看。通过上面这种系统自带命令,我们可以比较便捷地监控系统状态,因而帮助我们维护系统或定位问题。欢迎留言补充或更正。