查看 Linux 下 CPU、内存的占用率的方法集锦

如何查看 Linux 下内存占用率方法一 :

我们可以使用下面命令的组合来达到此目的。在该方法中,我们使用的是 free 和 awk 命令的组合来获取内存占用率。

要获取不包含百分比符号的内存占用率:

#free -t | awk ‘NR ==2 {print "CurrentMemory Utilization is: "$3/$2*100}‘

#free -t | awk ‘FNR ==2 {print"Current Memory Utilization is: "$3/$2*100}‘

Current Memory Utilization is : 18.0433

要获取包含百分比符号及保留两位小数的内存占用率:

#free -t | awk ‘NR == 2{printf("Current Memory Utilization is : %.2f%"), $3/$2*100}‘

#free -t | awk ‘FNR == 2{printf("Current Memory Utilization is : %.2f%"), $3/$2*100}‘

Current Memory Utilization is : 18.06%

键入 free 命令会更好地作出阐释:

[email protected]:~# free

          total        used        free      shared buff/cache   available

Mem: 1024780 185096 783012 1036 56672 769256

Swap: 0 0 0

细节如下:

free:是一个标准命令,用于在Linux 下查看内存使用情况。

awk:是一个专门用来做文本数据处理的强大命令。

FNR == 2:该命令给出了每一个输入文件的行数。其基本上用于挑选出给定的行(针对于这里,它选择的是行号为 2 的行)

NR == 2:该命令给出了处理的行总数。其基本上用于过滤给出的行(针对于这里,它选择的是行号为 2 的行)

$3/$2*100:该命令将列 3 除以列 2 并将结果乘以 100。

printf:该命令用于格式化和打印数据。

%.2f%:默认情况下,其打印小数点后保留 6 位的浮点数。使用后跟的格式来约束小数位。

如何查看 Linux 下内存占用率方法二:

我们可以使用下面命令的组合来达到此目的。在这种方法中,我们使用 free、grep 和 awk 命令的组合来获取内存占用率。

要获取不包含百分比符号的内存占用率:

#free -t | grep Mem | awk ‘{print"Current Memory Utilization is : " $3/$2*100}‘

Current Memory Utilization is : 18.071

要获取包含百分比符号及保留两位小数的内存占用率:

free -t | grep Mem | awk‘{printf("Current Memory Utilization is : %.2f%"), $3/$2*100}‘

Current Memory Utilization is : 18.07%

如何查看 Linux 下 CPU 的占用率方法一:

我们可以使用如下命令的组合来达到此目的。在这种方法中,我们使用 top、print 和 awk 命令的组合来获取CPU 的占用率。

如果在输出中展示的是多个 CPU 的情况,那么你需要使用下面的方法。

#top -b -n1 | grep ^%Cpu

%Cpu(s): 0.1 us, 0.4 sy, 0.0 ni, 99.4 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st

要获取不包含百分比符号的 CPU 占用率:

#top -b -n1 | grep ^%Cpu | awk‘{cpu+=$9}END{print "Current CPU Utilization is : " 100-cpu/NR}‘

Current CPU Utilization is : 100

要获取包含百分比符号及保留两位小数的 CPU 占用率:

#top -b -n1 | grep ^%Cpu | awk‘{cpu+=$9}END{printf("Current CPU Utilization is : %.2f%"),100-cpu/NR}‘

Current CPU Utilization is : 100.00%

如何查看 Linux 下 CPU 的占用率方法二:

我们可以使用如下命令的组合来达到此目的。在这种方法中,我们使用的是 top、print/printf 和 awk 命令的组合来获取 CPU 的占用率。

如果在单个输出中一起展示了所有的 CPU 的情况,那么你需要使用下面的方法。

#top -b -n1 | grep ^%Cpu

%Cpu(s): 0.1 us, 0.4 sy, 0.0 ni, 99.5 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st

要获取不包含百分比符号的 CPU 占用率:

#top -b -n1 | grep ^%Cpu | awk ‘{print"Current CPU Utilization is : " 100-$8}‘

Current CPU Utilization is : 0.5

要获取包含百分比符号及保留两位小数的 CPU 占用率:

#top -b -n1 | grep ^%Cpu | awk‘{printf("Current CPU Utilization is : %.2f%"), 100-$8}‘

Current CPU Utilization is : 0.50%

如下是一些细节:

top:是一种用于查看当前 Linux系统下正在运行的进程的非常好的命令。

-b:选项允许 top 命令切换至批处理的模式。当你从本地系统运行 top 命令至远程系统时,它将会非常有用。

-n1:迭代次数。

^%Cpu:过滤以 %CPU 开头的行。

awk:是一种专门用来做文本数据处理的强大命令。

cpu+=$9:对于每一行,将第 9 列添加至变量 cpu。

printf:该命令用于格式化和打印数据。

%.2f%:默认情况下,它打印小数点后保留 6 位的浮点数。使用后跟的格式来限制小数位数。

100-cpu/NR:最终打印出CPU 平均占用率,即用 100 减去其并除以行数。

相信小伙伴们一定已经掌握了几种方法,如果有其他便捷的方法,可以在评论区一块沟通哦~

原文地址:https://blog.51cto.com/14586215/2447109

时间: 2024-08-14 03:43:53

查看 Linux 下 CPU、内存的占用率的方法集锦的相关文章

linux下常见内存异常查证工具和方法介绍

linux下常见内存异常查证工具和方法介绍 内存异常导致的异常往往很难查证,本文介绍在linux下的各种常见内存异常的查证工具和方法. 1.访问空指针/未初始化指针 这个是最简单的内存异常了,只要能够生成coredump文件,可以快速定位问题代码. 开启coredump 部分环境下默认不会生成coredump,需要运行如下命令:ulimit -c unlimited //unlimited表示不限制coredump文件大小,也可以指定一个最大文件大小. 定制core文件名 默认的coredump

linux 系统性能分析(top命令)及更准确解读内存的占用率(free -m 命令)

一.系统性能分析(top命令) top 命令是 Linux 下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,默认5秒刷新一下进程列表,所以类似于 Windows 的任务管理器. 系统整体当下的统计信息 top命令显示的前五行是系统整体的统计信息. 第一行是任务队列信息,同uptime命令的执行结果.eg. top  -  15:09:51  up  17  days  ,  3:38  ,  4  users  ,  load  average  :  1.09  ,  3.39

[转帖]linux下CPU、内存、IO、网络的压力测试,硬盘读写速度测试,Linux三个系统资源监控工具

linux下CPU.内存.IO.网络的压力测试,硬盘读写速度测试,Linux三个系统资源监控工具 https://blog.51cto.com/hao360/1587165 linux_python关注0人评论57974人阅读2014-12-06 20:17:16 一.对CPU进行简单测试: 1.通过bc命令计算特别函数 例:计算圆周率 echo "scale=5000; 4*a(1)" | bc -l -q MATH LIBRARY        If bc is invoked w

zabbix监控LINUX下CPU,硬盘,流量,内存

1.LINUX下zabbix客户端安装 [[email protected] ~]# mkdir /usr/local/zabbix [[email protected] ~]# mv zabbix_agents_2.0.3.linux2_6.amd64.tar.gz /usr/local/zabbix/ [[email protected] ~]# cd /usr/local/zabbix/ [[email protected] zabbix]# tar zxvf zabbix_agents_

清除list或者map集合,减少内存的占用率

1.在编写程序对数据处理的时候我们经常会使用到list和map集合,有些时候我们存到集合里的数据只是暂时性的,在验证完或者使用完之后尽量对list或者map清空,及list.clear()后者map.clear(), 这样我们可以大大减轻服务器内存被占用率,特别是处理数据量比较大的验证以及过滤的时候,对于程序的性能以及运行速度都是影响很大的. 2.程序中我们经常会遇见把数据存到excel中然后经过中间件进入数据库中,这样的数据需要经过一系列的验证到最后只是把正确的数据保存到数据库中,错误的直接过

Linux 下释放内存,swap交换区缓存

关于内存耗尽的总结: 1)在进程收到OOM之前,内核将刷新文件系统的cache来释放空间. 2)将交换区的页面移到磁盘上. 3)当内存变少时,虚拟性使每个进程通过交换区来做简单的上下文环境切换. 4)当进程消耗尽交换内存后,才会引发out-of-memory(OOM)来kill那些进程. 所以,我们还是有必要来手动进行Linux下释放内存的操作,其实也就是释放缓存的操作了. 要达到释放缓存的目的,我们首先需要了解下关键的配置文件/proc/sys/vm/drop_caches.这个文件中记录了缓

【调试】Linux下超强内存检测工具Valgrind

[调试]Linux下超强内存检测工具Valgrind 内容简介 Valgrind是什么? Valgrind的使用 Valgrind详细教程 1. Valgrind是什么? Valgrind是一套Linux下,开放源代码(GPLV2)的仿真调试工具的集合.Valgrind由内核(core)以及基于内核的其他调试工具组成. 内核类似于一个框架(framework),它模拟了一个CPU环境,并提供服务给其他工具:而其他工具则类似于插件 (plug-in),利用内核提供的服务完成各种特定的内存调试任务.

查看linux下的内存条数  

1.内存条数: dmidecode|grep -P -A5 "Memory\s+Device"|grep Size|grep -v Range 2.内存最大容量: dmidecode|grep -P 'Maximum\s+Capacity' 3.内存频率: dmidecode|grep -A16 "Memory Device"|grep Speed 查看linux下的内存条数

linux下的内存分布

周日讲了32位linux下的内存分布 还有关于C语言中的extern和static的用法 内存的最高1G是用作系统保留,接下来是占空间,在靠近3G的那一块 再下来是堆空间,之后是bss区,未初始化的静态变量区 然后是Rw data区 Ro data区,主要用作存储字符串类型 接下来是代码段,又名txt正文段 0xffffffff 内核 0xbfff ffff 栈 堆 bss区 rw data ro data 代码段 0x00000000 接下来就是验证 1 #include <stdio.h>