怎么查看机器IO占用情况?
iostat 或 sar

怎么查看机器网络状况?
dstat

top指令

一.信息显示 
Linux系统可以通过top命令查看系统的CPU、内存、运行时间、交换分区、执行的线程等信息。通过top命令可以有效的发现系统的缺陷出在哪里。是内存不够、CPU处理能力不够、IO读写过高….

注意:点击c可以显示详细的命令

[root@foundation6 docker]# top

top - 21:31:26 up 15:16,  5 users,  load average: 0.61, 0.82, 0.75
Tasks: 240 total,   2 running, 238 sleeping,   0 stopped,   0 zombie
%Cpu(s): 13.7 us,  1.5 sy,  0.0 ni, 84.2 id,  0.6 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  3775264 total,   250100 free,  2495300 used,  1029864 buff/cache
KiB Swap:  4064252 total,  2789544 free,  1274708 used.   527664 avail Mem

PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND    
16507 kiosk     20   0 1935284 201988  10816 R  46.8  5.4  68:11.92 plugin-con+
15773 kiosk     20   0 1784208 497692  40776 S   4.7 13.2  37:05.32 firefox    
  408 root      20   0   36940   4116   3920 S   3.0  0.1   4:51.67 systemd-jo+
 3789 kiosk     20   0  747664  14124   4696 S   2.0  0.4   2:49.76 gnome-term+
 2404 root      20   0  439488 106688  84580 S   1.7  2.8  16:08.35 Xorg       
 2662 kiosk      9 -11  700096   5232   3032 S   1.7  0.1   5:17.25 pulseaudio 
21632 kiosk     20   0  812940 167440  30100 S   1.7  4.4  20:15.48 wps        
 2688 kiosk     20   0 2111764 218776  18580 S   1.3  5.8  20:25.33 gnome-shell
  663 root      20   0  399976   3352   2984 S   1.0  0.1   0:46.92 rsyslogd   
 7349 qemu      20   0 1697464 956932    556 S   0.7 25.3   5:03.80 qemu-kvm   
 7803 qemu      20   0 1697460 708164    544 S   0.7 18.8   4:16.74 qemu-kvm   
   18 root      20   0       0      0      0 S   0.3  0.0   0:16.94 rcuos/0    
   19 root      20   0       0      0      0 S   0.3  0.0   0:18.43 rcuos/1    
   21 root      20   0       0      0      0 S   0.3  0.0   0:19.62 rcuos/3    
  671 root      20   0  207984    160    120 S   0.3  0.0   0:01.60 abrt-watch+
 5676 root      20   0       0      0      0 S   0.3  0.0   0:00.28 kworker/u1+
    1 root      20   0  189128   2900   1432 S   0.0  0.1   0:06.11 systemd

top命令的第一行:

top - 21:31:26 up 15:16,  5 users,  load average: 0.61, 0.82, 0.75
依次对应:系统当前时间 up 系统到目前为止i运行的时间, 当前登陆系统的用户数量, load average后面的三个数字分别表示距离现在一分钟,五分钟,十五分钟的负载情况。 
这行信息与命令uptime显示的信息相同 
注意:load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

top命令的第二行:
Tasks: 240 total,   2 running, 238 sleeping,   0 stopped,   0 zombie
依次对应:tasks表示任务(进程),240 total则表示现在有240个进程,其中处于运行中的有2个,238个在休眠(挂起),stopped状态即停止的进程数为0,zombie状态即僵尸的进程数为0个。

top命令的第三行,cpu状态:

%Cpu(s): 13.7 us,  1.5 sy,  0.0 ni, 84.2 id,  0.6 wa,  0.0 hi,  0.0 si,  0.0 st
依次对应: 
us:user 用户空间占用cpu的百分比 
sy:system 内核空间占用cpu的百分比 
ni:niced 改变过优先级的进程占用cpu的百分比 
id:空闲cpu百分比 
wa:IO wait IO等待占用cpu的百分比 
hi:Hardware IRQ 硬中断 占用cpu的百分比 
si:software 软中断 占用cpu的百分比 
st:被hypervisor偷去的时间

top命令第四行,内存状态:

KiB Mem :  3775264 total,   250100 free,  2495300 used,  1029864 buff/cache
依次对应:物理内存总量(3.7G),空闲内存总量(2.5G),使用中的内存总量(2.4G),缓冲内存量 
第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心 
top命令第五行,swap交换分区:

KiB Swap:  4064252 total,  2789544 free,  1274708 used.   527664 avail Mem 
依次对应:交换区总量(4G),空闲交换区总量(2.7G),使用的交换区总量(1.2G),可用交换取总量

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

top命令第六行是空行

top命令第七行,各进程的监控:

PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND    
依次对应: 
PID — 进程id 
USER — 进程所有者 
PR — 进程优先级 
NI — nice值。负值表示高优先级,正值表示低优先级 
VIRT — 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES 
RES — 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA 
SHR — 共享内存大小,单位kb 
S — 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程 
%CPU — 上次更新到现在的CPU时间占用百分比 
%MEM — 进程使用的物理内存百分比 
TIME+ — 进程使用的CPU时间总计,单位1/100秒 
COMMAND — 进程名称(命令名/命令行)

二.交互命令 
1.1 ‘h’ 帮助 
top命令进入视图后,键入h会显示如下界面,显示交互命令的帮助菜单

1.2 敲ENTER或者 SPACE键: 刷新显示

1.3 A’: 切换交替显示模式 
top命令视图下,键入‘A‘显示如下:

显示4个窗口:Def (默认字段组) 
Job (任务字段组) 
Mem (内存字段组) 
Usr (用户字段组) 
四组字段共有一个独立的可配置的概括区域和它自己的可配置任务区域。4个窗口中只有一个窗口是当前窗口。当前窗口的名称显示在左上方。(注:只有当前窗口才会接受你键盘交互命令) 
我们可以用’a’和’w’在4个 窗口间切换。’a’移到后一个窗口,’w’移到前一个窗口。用’g’命令你可以输入一个数字来选择当前窗口。 
在键入‘A‘后在键入‘a‘的显示如下:

1.4 ‘B’: 触发粗体显示 
一些重要信息会以加粗字体显示。这个命令可以切换粗体显示

1.5 ‘d’ 或‘s’: 设置显示的刷新间隔 
当键下’d’或’s’时,你将被提示输入一个值(以秒为单位),它会以设置的值作为刷新间隔。如果你这里输入了6.0,top将会每秒刷新 
1.6 ‘l’、‘t’、‘m’: 切换负载、任务、内存信息的显示

1.7 ‘f’: 字段管理 
用于选择你想要显示的字段。用’*’标记的是已选择的。

上下光标键在字段内导航,左光标键可以选择字段,回车或右光标键确认。

按’<’移动已排序的字段到左边,’>’则移动到右边。

1.8 ‘R’: 反向排序

1.9 ‘c’: 触发命令 
切换是否显示进程启动时的完整路径和程序名。

键入‘c’后显示: 
2.0 ‘i’: 空闲任务 
切换显示空闲任务

参考于:https://blog.csdn.net/csdn066/article/details/77171018,https://www.cnblogs.com/ftl1012/p/iostat.html

top中的load average值的含义--针对的是cpu

1 单核处理器
假设我们的系统是单CPU单内核的,把它比喻成是一条单向马路,把CPU任务比作汽车。当车不多的时候,load <1;当车占满整个马路的时候 load=1;当马路都站满了,而且马路外还堆满了汽车的时候,load>1
2 多核处理器
我们经常会发现服务器Load > 1但是运行仍然不错,那是因为服务器是多核处理器(Multi-core)。
假设我们服务器CPU是2核,那么将意味我们拥有2条马路,我们的Load = 2时,所有马路都跑满车辆。
注:查看cpu 核数命令: 
grep 'model name' /proc/cpuinfo | wc -l
3 什么样的Load average值要提高警惕
0.7 < load < 1: 此时是不错的状态,如果进来更多的汽车,你的马路仍然可以应付。
load = 1: 你的马路即将拥堵,而且没有更多的资源额外的任务,赶紧看看发生了什么吧。
load > 5: 非常严重拥堵,我们的马路非常繁忙,每辆车都无法很快的运行
4 三种Load值,应该看哪个
通常我们先看15分钟load,如果load很高,再看1分钟和5分钟负载,查看是否有下降趋势。
1分钟负载值 > 1,那么我们不用担心,但是如果15分钟负载都超过1,我们要赶紧看看发生了什么事情。所以我们要根据实际情况查看这三个值

swap和内存

swap是什么?
Linux系统的Swap分区,即交换区,Swap空间的作用可简单描述为:当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap空间中,等到那些程序要运行时,再从Swap中恢复保存的数据到内存中。这样,系统总是在物理内存不够时,才进行Swap交换。其实,Swap的调整对Linux服务器,特别是Web服务器的性能至关重要。通过调整Swap,有时可以越过系统性能瓶颈,节省系统升级费用。

什么时候使用swap?
交换分区并不是等到物理内存用尽了才使用的,是否尽量的使用或不使用swap,在内核空间有一个参数控制。

内核空间交换区分利用参数查看命令:cat /proc/sys/vm/swappiness
参数说明:
swappiness=0 的时候表示最大限度使用物理内存,然后才是swap空间;swappiness=100 的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。
考虑到以下情况:
1)安装系统时难以确定内存的负荷,如何设置交换分区大小。
2)系统中物理内存越大,所需交换分区就会越少。

swap大小设置
平时安装系统,swap默认都分内存的2倍,因为现在有硬盘空间都很大,也不在乎那几十G的空间。合理建议:

参考:https://blog.csdn.net/libaoan1971/article/details/52931284
https://blog.csdn.net/mengxingyuanlove/article/details/50992657

wa:cpu等待磁盘写入完成时间

如果一台机器看到wa特别高,那么一般说明是磁盘IO出现问题,可以使用iostat等命令继续进行详细分析。
iotop的命令可以看到具体是哪个进程占用 IO 高
如果要看具体是哪个磁盘 IO 高,则用

查看服务器IO状态-iostat

说明:

cpu属性值说明:

%user:CPU处在用户模式下的时间百分比。

%nice:CPU处在带NICE值的用户模式下的时间百分比。

%system:CPU处在系统模式下的时间百分比。

%iowait:CPU等待输入输出完成时间的百分比。

%steal:管理程序维护另一个虚拟处理器时,虚拟CPU的无意识等待时间百分比。

%idle:CPU空闲时间百分比。

备注:

如果%iowait的值过高,表示硬盘存在I/O瓶颈

如果%idle值高,表示CPU较空闲

如果%idle值高但系统响应慢时,可能是CPU等待分配内存,应加大内存容量。

如果%idle值持续低于10,表明CPU处理能力相对较低,系统中最需要解决的资源是CPU。

device属性值说明:

tps:该设备每秒的传输次数

kB_read/s:每秒从设备(drive expressed)读取的数据量;

kB_wrtn/s:每秒向设备(drive expressed)写入的数据量;

kB_read:  读取的总数据量;

kB_wrtn:写入的总数量数据量;

dstat这个命令也很有用?

展示net、cpu、load、dsk、memory、swap、system等内容,
注意提供了net相关状态
有一个好处是可以将结果输出到csv
# dstat –output /tmp/sampleoutput.csv -cdn
结果如下图:

top和iostat指令的使用,linux负载,swap与内存,io相关推荐

  1. Linux负载CPU、内存、磁盘IO、网络IO状态分析详解

    一.Linux系统状态概述 1.Linux系统状态分析工具 和上面图是同一个链接: Linux 性能观测工具: Basic Tool有如下: uptime.top(htop).mpstat.issta ...

  2. Linux基础命令---iostat--显示IO状态

    iostat iostat指令用来显示cpu状态,系统IO设备的状态,以及相关磁盘和NFS使用状态.iostat命令通过观察设备相对于其平均传输速率的活动时间来监视系统输入/输出设备负载.iostat ...

  3. 解决Linux 负载过高问题过程记录

    解决问题的思路 1.top命令查看该机器的负载状况 2.cd  /proc/pid 查看对应高占用程序的位置 3.进入对应程序中查看日志,根据CPU和内存这两个因素分析 4.ps -ajxf 查看进程 ...

  4. linux 负载高 标准,linux 系统负载高 如何检查

    1:load Average 1.1:什么是Load?什么是Load Average? Load 就是对计算机干活多少的度量(WikiPedia:the system Load is a measur ...

  5. MySQL orzdba、dodba、top、iostat、vmstat、perf等

    1 mysq自带的mysqladmin命令 mysqladmin -usystem -p*** -h127.0.0.1 -P3306 -r -i 1 extended-status \|grep &q ...

  6. Linux CentOs7 监控CPU 内存 硬盘IO读写,网络负载,CPU温度等

    一般我们都知道TOP命令可以加载服务器的负载详情,但界面不太友好.因此用到htop 我们开发的软件服务需要在服务器上运行,所以服务器性能代表了软件的性能上限,因此服务器性能调优是个十分重要的环节,然而 ...

  7. Linux负载均衡软件LVS

    Linux负载均衡软件LVS之三(配置篇) LVS集群有DR.TUN.NAT三种配置模式,可以对www服务.FTP服务.MAIL服务等做负载均衡,下面通过搭建www服务的负载均衡实例,讲述基于DR模式 ...

  8. top刷新间隔_每天一个linux命令:top命令

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.下面详细介绍它的使用方法.top是一个动态显示过程,即可以通过用户按键来不断刷新 ...

  9. 【Linux负载均衡】

    Linux负载均衡 核心结构体 核心函数 load_balance fair.c 核心数据结构 调用核心函数1 should_we_balance() 核心数据结构 核心辅助函数 核心函数 核心调用函 ...

最新文章

  1. 算法----------字符串相乘(Java 版本)
  2. Netflix Play API:我们为什么构建了一个演进式架构?
  3. Linux 安装json神器 jq
  4. 【Qt开发经验】Qt信号槽连接不成功问题原因汇总
  5. java字典树(Trie)实现中文模糊匹配
  6. button设置disabled属性不生效_jQuery属性节点
  7. 基于Echarts+HTML5可视化数据大屏展示—Echart图例使用
  8. ural 1012K-based Numbers. Version 2 1013. K-based Numbers. Version 3
  9. 快速下载网页全部图片的方法
  10. ARP命令详解和解决ARP攻击
  11. 温度能够瞬间提升到千度以上?究竟是什么原理
  12. J - Janitor Troubles 三分 海伦公式
  13. DS线性表—多项式相加
  14. QQ音乐推荐歌单API报错 invalid referer
  15. 大四会计转码 初学c语言的心路历程
  16. 什么叫幂等?如何实现幂等性?
  17. 【转载】Android 面试总结
  18. JAVA 酒店预订系统
  19. android红米机型适配,#MIUI#关于红米手机4高配版 Android版本适配的说明【miui9吧】_百度贴吧...
  20. 解决方案~Microsoft Security Client OOBE 程序错误

热门文章

  1. 企业业务的 WPA3 安全性为啥如此重要?
  2. Unity 360全景图转换为天空盒子
  3. RK3288 开发板 排插物理引脚对应图以及如何进入android6.0.1内核终端、uboot终端
  4. 概率论与数理统计——重复抽样与不重复抽样的判定
  5. 为什么很多人家里不准备尺子了?手机怎么测量长度?
  6. 关于Smartphone的智能手机键盘输入法的疑惑
  7. 内存数据库-H2简介与实践
  8. 学习编程语言的第一步,认识什么是计算机!!!
  9. 微信屏蔽抖音?扎克伯格登报发表道歉信
  10. Apache Thrift 介绍