Linux系统管理技巧

[toc]shell

Linux系统管理技巧

10.1 w 命令,查看当前系统的负载

用法以下数据库

[root@localhost ~]# w
 15:15:19 up 2 min,  1 user,  load average: 0.05, 0.08, 0.04
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/0    192.168.72.1     15:14    7.00s  0.08s  0.00s w

1. load average

第一行从左面开始显示的信息依次为:时间,系统运行时间,登陆用户数,平均负载。 第二行开始以及下面全部的行,告诉咱们:当前登陆的都有哪些用户,以及他们是从哪里登陆的等等。其实,在这些信息当中,咱们最应该关注的应该是第一行中的 ‘load average:’ 后面的三个数值。缓存

第一个数值表示1分钟内系统的平均负载值;(最能体现当前负载的工做状况)服务器

第二个数值表示5分钟内系统的平均负载值;工具

第三个数值表示15分钟系统的平均负载值。性能

咱们着重看中第一个值,它表示单位时间段内CPU活动进程数。固然这个值越大就说明你的服务器压力越大。通常状况下这个值只要不超过服务器的cpu数量就没有关系,若是服务器cpu数量为8,那么这个值若小于8,就说明当前服务器没有压力,不然就要关注一下了。ui

uptime和w命令的第一行是如出一辙;由于w信息丰富,咱们通常用w

[root@xaviyunserver ~]# w
 17:45:35 up 64 days,  9:47,  1 user,  load average: 0.00, 0.01, 0.05
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/0    221.224.0.190    17:44    7.00s  0.00s  0.00s w
[root@xaviyunserver ~]# uptime
 17:48:13 up 64 days,  9:49,  1 user,  load average: 0.00, 0.01, 0.05

2. 查看cpu核心数量, cat /proc/cpuinfo

[root@localhost ~]# cat /proc/cpuinfo

mark

这里的processor计数从0开始,也就是说一个显示为0,二个显示为1.net

mark

3. uptime 实时查看,同W第一行

[root@localhost ~]# uptime
 15:44:37 up 32 min,  1 user,  load average: 0.00, 0.01, 0.05

4. 查看当前系统有几个cpu,grep -c 'processor' /proc/cpuinfo

[root@localhost ~]# grep -c 'processor' /proc/cpuinfo
2

10.2 用vmstat 命令监控系统的状态(是否瓶颈)

用法以下: markcode

vmstat命令打印的结果共分为6部分:procs, memory, swap, io, system, cpu.。请重点关注一下r、b、si、 so、bi、bo、wa几列。server

#vmstat           //显示当前系统状态
#vmstat 1       //每隔1秒输出一次运行状态,能够是其余任意数值,ctrl+c终止
#vmstat 1 5     //每隔1秒输出一次运行状态,输出5次后终止

mark

1.procs显示进程的相关信息 r、b

  • [ ] r (run):表示运行或等待CPU时间片的进程数。说明:不要误觉得等待CPU时间片意味着这个进程没有进行,实际上某一时刻一个CPU只能有一个进程,其余进程只能排着队等着,此时这些排队等待CPU资源的进程依然是运行状态。该数值若是长期大于服务器CPU的个数,则说明CPU资源不够用了。
  • [ ] b (block):表示等待资源的进程数,这个资源指的是I/O、内存等。举个例子:当磁盘读写很是频繁时,写数据就会很是慢,此时CPU运算很快就结束了,但进程须要把计算的结果写入磁盘,这样进程的任务才算完成,那此时这个进程只能慢慢地等待,这样这个进程就是这个b状态。该数值若是长时间大于1,则须要关注一下。

2.memory显示内存的相关信息 swpd、free、buff、cache:

  • [ ] swpd:表示切换到交换分区中的内存数量,单位为KB。
  • [ ] free:表示当前空闲的内存数量,单位为KB。
  • [ ] buff:表示(即将写入磁盘的)缓冲大小,单位为KB。
  • [ ] cache:表示(从磁盘中读取的)缓存大小,单位为KB。

3.swap显示内存的交换状况 si、so

  • [ ] si:表示由交换区写入内存的数据量,单位为KB。
  • [ ] so:表示由内存写入交换区的数据量,单位为KB。

4.io显示磁盘的使用状况 bi、bo

  • [ ] bi:表示从块设备读取数据的量(读磁盘),单位为KB。
  • [ ] bo:表示从块设备写入数据的量(写磁盘),单位为KB。

5.system显示采集间隔内发生的中断次数 in、cs

  • [ ] in:表示在某一时间间隔内观测到的每秒设备的中断次数。
  • [ ] cs:表示每秒产生的上下文切换次数。

6.cpu显示CPU的使用状态 us、sy、id、wa、st

  • [ ] us:显示用户下花费CPU的时间百分比。
  • [ ] sy:显示系统花费CPU的时间百分比。
  • [ ] id:表示CPU处于空闲状态的时间百分比。
  • us+sy+id =100%
  • [ ] wa:wait 表示I/O等待所占用CPU的时间百分比,wa数值很大,说明CPU不够用了
  • [ ] st:表示被偷走的CPU所占百分比(通常都为0,不用关注),服务器被虚拟化后会被偷走一部分CPU

以上所介绍的各个参数中,常常会关注r列,b列,和wa列,三列表明的含义在上边说得已经很清楚。IO部分的bi以及bo也是要常常参考的对象。若是磁盘io压力很大时,这两列的数值会比较高。另外,当si, so两列的数值比较高,而且在不断变化时,说明内存不够了,内存中的数据频繁交换到交换分区中,这每每对系统性能影响极大。**

10.3 top命令显示进程所占系统资源

用法以下: mark 解析:一共119个常常,2个运行,117个处于休眠状态(未被激活),0个中止,0个zombie(僵尸进程)即主进程被意外中止了,留下了一些子进程,比较尴尬,只能自生自灭。 Top命令用于动态监控进程所占系统资源,每隔3秒变一次。这个命令的特色是把占用系统资源(CPU,内存,磁盘IO等)最高的进程放到最前面。

1. top命令打印出了不少信息,loadaverage、tasks、%CPU、%MEM、RES. 包括系统负载(loadaverage)、进程数(Tasks)、cpu使用状况、内存使用状况以及交换分区使用状况。

  • [ ] KiB Mem&Swap,物理内存和交换分区的使用状况,关注的是物理内存中的buff/cache

  • [ ] %CPU cpu的使用状况,和系统负载loadaverage没有关系,系统负载很高,而CPU%低的状况

  • [ ] %MEM 使用内存的百分比

  • [ ] RES 进展所占的内存大小,单位为Kbyte

2. 输入top指令后,M键查看内存,P键查看CPU%,数字1查看各个CPU

按大写的M查看%MEN,并以大到小排序;

按大写P,%CPU的使用状况,按照大小顺序排列。

按下数字1,产看每一个CPU的占用状况 mark 按数字1切换 mark

3. top -c 查看详细的进程信息,以及常常对于的命令(路径)

mark

4. top -bn1 静态显示全部进程,表示了非动态打印系统资源的使用状况,在shell脚本中经常使用

mark

5. 同时须要关注的是PID,能够用kill命令+PID 杀死该进程.

10.4 sar命令监控系统状态

sar 命令很强大,它能够监控系统全部资源状态,好比平均负载、网卡流量、磁盘状态、内存使用等等。它不一样于其余系统状态监控工具的地方在于,它能够打印历史信息,能够显示当天从零点开始到当前时刻的系统状态信息。若是你系统没有安装这个命令,请使用 yum install -y sysstat命令安装。

1. yum install -y systat 安装,不能直接执行sar

初次使用sar命令会报错,那是由于sar工具尚未生成相应的数据库文件(时时监控就不会了,由于不用去查询那个库文件)。它的数据库文件在 “/var/log/sa/” 目录下,每10分钟抓一次,生成文件保存在该目录下。

mark

2. 查看网卡流量 sar -n DEV,IFACE/rxpack/txpck/rxkB/txkB

sar -n DEV 1 10 //每一个1秒显示一次,一共显示10次

用法以下: mark

这个命令把监听记录的网卡信息打印出来,每隔10分钟记录一次。如下参数是重点关注的。

IFACE:表示网卡设备名称.

rxpck/s:表示每秒进入收取的包的数量有多少,几千是正常的,若是上万说明被攻击了

txpck/s:表示每秒发送出云的包的数量有多少。

rxkB/s:表示每秒收取的数据量(单位为KB)。

txkB/S:表示每秒发送的数据量

剩下后面几列不须要关注。若是有一天你所管理的服务器丢包很是严重,那么你就应该看一看这个网卡流量是否异常了,若是rxpck/s 那一列的数值大于**4000**,或者rxbyt/s那列大于5000000则颇有多是被攻击了,正常的服务器网卡流量不会高于这么多,除非是你本身在拷贝数据。这是你须要实时查看网卡流量

#### sar -n DEV 1 5  //每隔1秒输出一次网卡流量状态,5次后终止

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/K079IkLEaH.png?imageslim)

### 3.使用sar -n DEV -f 选项查看某一天的网卡流量历史,后面跟文件名.

可是/var/log/sa/saXX 只能保存一个月

#sar -n DEV -f /var/log/sa/sa27

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/dBA8jF7l1l.png?imageslim)

### 4. 查看历史负载 sar -q 这个命令有助于咱们查看服务器在过去某个时间的负载情况.
![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/k5clFlI601.png?imageslim)

### 5. sar -b 查看磁盘负载,读写状况。

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/HA5h7gfk09.png?imageslim)

sar -b 1 5 //每隔1秒输出一次磁盘负载状态,5次后终止

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/jEb2B1d96B.png?imageslim)

## 10.5 用nload命令查看网卡流量

sar虽然能够查看网卡流量,可是不够直观,还有一个更好用的工具,那就是nload。
### 1. 安装nload:

[root@localhost ~]# yum install -y nload

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/dF5GeLLb0D.png?imageslim)

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/De97mfKd5d.png?imageslim)

### 2. 用↑,↓键切换不一样网卡的流量监控状况
> ncoming为进入网卡的流量。

> Outgoing为网卡出去的流量。

> 主要关注Curr那行的数据,其单位也能够动态自动调整,很人性化。

> 按q退出该界面。

### 3. 在/var/log/sa/目录下的saXX和sarXX,XX为日期,saXX是二进制文件,只能用sar -f命令查看,而sar文件是须要一天才能生成的,能够用cat命令查看

![mark](http://p0weeraap.bkt.clouddn.com/xavi2017/180127/kbJA1DEHck.png?imageslim)
相关文章
相关标签/搜索