Linux内存性能指标、CPU性能指标

内存性能指标

内存基础概念

先执行一下 top 命令,看结果中关于内存的相关部分

# top

其中的 VIRTRESSWAP 都是什么呢?

分别是下面的3个概念:

物理内存 Resident - RES

实际的内存空间 RAM

交换区 Swapped - SWAP

当物理内存不足时,操作系统会把内存中不常用的页换出到磁盘空间

当被换出的页需要被访问时,再换入到物理内存

所以交换区就是用来临时存放内存中不常用的内容的,感觉就想内存的一个小仓库

虚拟内存 Virtual - VIRT

虚拟内存 = 物理内存 + 交换区

程序操作内存时,实际就是操作虚拟内存中的地址,操作系统再负责映射到物理地址,或者交换区

快速了解内存状态

# free

主要指标

total - 物理内存总大小

used - 已经使用的物理内存大小

free - 空闲的物理内存

shared - 多个进程共享内存的大小

buffers/cached - 做为缓存的内存大小

swap - 交互空间的使用状态

关于内存的几个常见问题:

1、空闲空间少,是不是内存不够了?

其实linux中空闲的物理空间经常是很少的,和linux使用内存的思路有关

linux会尽量提高内存使用率,经常会把磁盘上的内容缓存到内存,用来加速

linux认为内存闲着也是闲着,还不如拿来做缓存

当内存不足时,linux就会释放缓存部分,让给真正需要的程序使用

2、buffer 和 cache 是什么区别?

buffer 缓存的是磁盘文件的元数据,例如文件属性、目录结构等等

cache 缓存的是真正的文件内容

3、如何判断内存真正不足?

内存不足主要有2个明显的表现

(1)持续的内存换入换出

(2)较多的主缺页中断

主缺页中断的概念:

缺页中断包含主/次缺页中断

次缺页中断,是在内存中可以找到目标页

主缺页中断,是在内存中找不到,需要到磁盘中找

所以较多的主缺页中断意味着较多的访问磁盘

可以通过 sar 命令查看指标

# sar -B 1 3

pgpgin/pgpgout 就是内存的换入换出

fault 次缺页中断

majflt 主缺页中断

vmstat 命令也可以查看一些内存信息

# vmstat 1 5

memory 部分是内存信息

si/so 是交换区的换入换出

补充技巧

执行top命令后,通常不会显示SWAP列,需要自己指定显示

在top的界面中点击‘f’,进入列编辑模式,按下字母‘p’, 会看到SWAP列被选中,然后按回车键返回top界面,SWAP列便显示出来了

CPU 性能指标

CPU性能指标可以从两方面来看:静态动态

静态指标主要包括:

CPU的型号、主频、核数、cache等

动态指标主要包括:

CPU的平均负载状况、CPU的使用率、最耗CPU的进程有哪些?

查看静态信息:

在服务器运行过程中,一般我们比较少关注CPU的静态信息,但我们刚开始拿到一台服务器时,就会很关心静态信息了

好根据这些信息判断分配给这台服务器多大的压力等

通过 /proc/cpuinfo 文件来查看

查看动态信息:

服务器变慢时,通常会先查看下CPU的负载是否过高,如果高了,再看下是哪些进程最耗费CPU,CPU使用率也是重要指标,让我们知道CPU消耗在哪些部分

01、CPU负载状况

通过负载信息能够直观的了解到CPU的压力状况,linux会给出最近1分钟、5分钟、15分钟的平均负载值

可以通过 top 命令查看

uptime 命令更加简洁直观

查看到负载值后,怎么判断CPU的负载是否过高呢?

有一个经验型的标准:

CPU负载上限值 = CPU的核数 * 4

例如是4核CPU,那么CPU的负载最好不要超过16,否则,CPU的压力就很大了

好比一个超市,有4个收银台,如果有16个顾客在排队结账,每个窗口4个人,顾客可以接受,收银员也不会感觉压力很大

02、耗费CPU的主要进程

发现CPU负载过高后,我们肯定想知道是谁把CPU搞的这么忙


通过 top 命令查看

ps 命令根据CPU使用量对进程排序

# ps -aux --sort -pcpu | less

03、CPU使用率

通过 top 命令查看

还可以查看每个核的使用率状况,执行 top 后按数字1键,就可以列出每个cpu的使用率

其中有几个主要信息项

id - CPU的空闲度

us - 用户进程对CPU的使用率

sy - 系统进程对CPU的使用率
 
wa - IO等待情况

st - 如果系统中运行了虚拟机,此项显示虚机使用CPU的情况

时间: 2024-12-29 23:18:40

Linux内存性能指标、CPU性能指标的相关文章

Linux CPU性能指标及解释

CPU Utilization - CPU使用率CPU Utilization是衡量程序占用系统资源的最直观指标,即CPU使用率.如果CPU Utilization在5%-10%之间则基本上对系统没有影响,可以不关注.但如果在80%-90%,或者更高的话,就可能出现处理器性能瓶颈了. User Time - 用户时间描述CPU耗费在用户进程上的百分比,包括Nice time.如果User Time值很高,则表明系统正在执行实际的工作. System Time - 系统时间描述CPU耗费在内核操作

CPU内存管理和linux内存分页机制

一.基本概念 物理地址(physical address) 用于内存芯片级的单元寻址,与处理器和CPU连接的地址总线相对应. ——这个概念应该是这几个概念中最好理解的一个,但是值得一提的是,虽然可以直接把物理地址理解成插在机器上那根内存本身,把内存看成一个从0字节一直到 最大空量逐字节的编号的大数组,然后把这个数组叫做物理地址,但是事实上,这只是一个硬件提供给软件的抽像,内存的寻址方式并不是这样.所以,说它是“与 地址总线相对应”,是更贴切一些,不过抛开对物理内存寻址方式的考虑,直接把物理地址与

Linux服务器的最大内存和CPU数

从网上查了很多资料.总算把linux下的内存和cpu个数搞清楚了.个人觉得使用linux系统的朋友都应该了解下.先公布如下,如有错误,请反馈给我.谢谢!! Linux系统/服务器能够支持的最大内存和CPU数. Intel X86 .最大CPU数: 32(包括逻辑CPU).最大内存: 64GB.最大文件大小: 8TB.最大文件系统大小(ext3): 16TB.最大每个进程的虚拟地址空间: 4GB AMD 64/EM64T .最大CPU数: 64.最大内存: 128GB.最大文件大小: 8TB.最大

查看linux/AIX系统内存及CPU占用百分比

1.linux下查看CPU及内存占用情况 查看内存占用百分比: [[email protected] ~]# free -m | sed -n '2p' | awk '{print "used mem is "$3"M,total mem is "$2"M,used percent is "$3/$2*100"%"}' used mem is 15765M,total mem is 15949M,used percent is

在Linux中通过Top运行进程查找最高内存和CPU使用率

按内存使用情况查找前15个进程,在批处理模式下为“top” 使用top命令查看有关当前状态,系统使用情况的更详细信息:正常运行时间,负载平均值和进程总数. 分类:Linux命令操作系统 2016-07-27 00:00:00 类似于前面的技巧有关找出由RAM和CPU使用率最高的进程 ,还可以使用top命令来查看相同的信息. 也许有相比前一个这种方法的一个额外的优势:顶级的“头”,提供有关当前状态和使用该系统的额外信息:正常运行时间,平均负载和进程总数,仅举几例例子. 按顶部查找按内存使用的进程

linux下查看CPU内存等信息

Linux查看物理CPU个数.核数.逻辑CPU个数 # 总核数 = 物理CPU个数 X 每颗物理CPU的核数  # 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数 # 查看物理CPU个数 [[email protected] ~]# cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l 2 # 查看每个物理CPU中core的个数(即核数) [[email protected] ~]# cat /pr

KVM的基础功能(网络、内存、cpu、存储的配置)

KVM的基础功能(网络.内存.cpu.存储的配置) cpu的配置 1)查看cpu插槽数量 [[email protected] ~]# cat /proc/cpuinfo |grep "physical id" |wc -l 24 2)查看cpu核心数量 [[email protected] ~]# cat /proc/cpuinfo |grep "core id"| wc -l 24 3)查看cpu的模型 [[email protected] ~]# cat /p

linux内存管理

一.Linux 进程在内存中的数据结构 一个可执行程序在存储(没有调入内存)时分为代码段,数据段,未初始化数据段三部分:    1) 代码段:存放CPU执行的机器指令.通常代码区是共享的,即其它执行程序可调用它.假如机器中有数个进程运行相同的一个程序,那么它们就可以使用同一个代码段.     2) 数据段:存放已初始化的全局变量.静态变量(包括全局和局部的).常量.static全局变量和static函数只能在当前文件中被调用.     3) 未初始化数据区(uninitializeddata s

zabbix自动发现与监控内存和CPU使用率最高的进程

监控需求 某项目的应用服务器CPU和内存使用率的监控,通过zabbix系统监控记录应用服务器上进程的CPU和内存的使用情况,并以图表的形式实时展现,以便于我们分析服务器的性能瓶颈. 监控方式 利用zabbix监控系统的自动发现功能,首先编写shell脚本获取服务器的CPU和内存资源使用率最大的进程,以json的格式输出,然后对这些进程的CPU和内存资源使用情况进行监控.(本文监控的进程为Linux服务器中资源使用率最高的10个进程.) 缺点 不适用于监控固定的进程 首先使用top命令查看进程状态