前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[422]linux查看CPU和内存使用率

[422]linux查看CPU和内存使用率

作者头像
周小董
发布2022-04-13 14:06:32
9K0
发布2022-04-13 14:06:32
举报
文章被收录于专栏:python前行者python前行者

文章目录

linux查看CPU和内存使用率

1:top

代码语言:javascript
复制
top -bn 1 -i -c

# 查看mongo
top -u mongod
image.png
image.png

top命令可以看到总体的系统运行状态和cpu使用效率

%us: 表示用户空间程序的cpu使用效率 %sy:表示系统空间程序的cpu使用效率 %ni: 表示用户空间通过nice调度过的程序的cpu使用效率 %id: 空闲cpu %wa:cpu运行时等待io的时间 %hi: cpu运行过程中硬中断的数量 %si: cpu处理软中断的数量 %st: 被虚拟机偷走的cpu

2: vmstat

每秒采集一次cpu使用率,采集5次

代码语言:javascript
复制
vmstat 1 5
image.png
image.png

3:sar

每秒采集一次cpu,共采集5次

代码语言:javascript
复制
sar -u 1 5
image.png
image.png

查看某个cpu的使用情况

代码语言:javascript
复制
sar -P 0 -u 1 5
image.png
image.png

进程队列长度和平均负载状态

代码语言:javascript
复制
sar -q 1 5
image.png
image.png

runq-sz:运行队列的长度(等待运行的进程数) plist-sz: 进程列表中的进程和线程数 ldavg-1:最后1分钟的平均负载 ldavg-5:过去5分钟的平均负载 ldavg-15:过去15分钟的系统平均负载

进程创建的平均值和上下文切换的此数

代码语言:javascript
复制
sar -w 1 5
image.png
image.png

4:dstat

每秒cpu使用率情况获取

代码语言:javascript
复制
dstat -c
image.png
image.png

最占cpu的进程获取

代码语言:javascript
复制
dstat --top-cpu
image.png
image.png

5: free -h

代码语言:javascript
复制
root@debian:~/zxf/trcap# free -h
              total        used        free      shared  buff/cache   available
Mem:           3.8G        1.9G        165M         31M        1.8G        1.7G
Swap:          4.0G         88K        4.0G
代码语言:javascript
复制
-b  以Byte为单位显示内存使用情况。 
-k  以KB为单位显示内存使用情况。 
-m  以MB为单位显示内存使用情况。
-g   以GB为单位显示内存使用情况。 
-o  不显示缓冲区调节列。 
-s   <间隔秒数>  持续观察内存使用状况。 
-t  显示内存总和列。 
-V  显示版本信息。 

命令示例:

代码语言:javascript
复制
free [-k] # 以 kb  为单位显示内存使用状况
free -g # 以 G 为单位显示内存使用状况
free -m # 以 M 为单位显示内存使用状况
free -t  # 以总和的形式显示内存的使用信息
free -s 1 # 每一秒显示内存使用情况
linux下free命令详解

free 命令显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存。

image
image

如果加上 -h 选项,输出的结果会友好很多:

image
image

有时我们需要持续的观察内存的状况,此时可以使用 -s 选项并指定间隔的秒数:

代码语言:javascript
复制
$ free -h -s 3
image
image

上面的命令每隔 3 秒输出一次内存的使用情况,直到你按下 ctrl + c。

由于 free 命令本身比较简单,所以本文的重点会放在如何通过 free 命令了解系统当前的内存使用状况。

输出简介

下面先解释一下输出的内容: Mem 行(第二行)是内存的使用情况。 Swap 行(第三行)是交换空间的使用情况。 total 列显示系统总的可用物理内存和交换空间大小。 used 列显示已经被使用的物理内存和交换空间。 free 列显示还有多少物理内存和交换空间可用使用。 shared 列显示被共享使用的物理内存大小。 buff/cache 列显示被 buffer 和 cache 使用的物理内存大小。 available 列显示还可以被应用程序使用的物理内存大小。

我想只有在理解了一些基本概念之后,上面的输出才能帮助我们了解系统的内存状况。

buff/cache

先来提一个问题: buffer 和 cache 应该是两种类型的内存,但是 free 命令为什么会把它们放在一起呢?要回答这个问题需要我们做些准备工作。让我们先来搞清楚 buffer 与 cache 的含义。

buffer 在操作系统中指 buffer cache, 中文一般翻译为 “缓冲区”。要理解缓冲区,必须明确另外两个概念:“扇区” 和 “块”。扇区是设备的最小寻址单元,也叫 “硬扇区” 或 “设备块”。块是操作系统中文件系统的最小寻址单元,也叫 “文件块” 或 “I/O 块”。每个块包含一个或多个扇区,但大小不能超过一个页面,所以一个页可以容纳一个或多个内存中的块。当一个块被调入内存时,它要存储在一个缓冲区中。每个缓冲区与一个块对应,它相当于是磁盘块在内存中的表示(下图来自互联网):

image
image

注意,buffer cache 只有块的概念而没有文件的概念,它只是把磁盘上的块直接搬到内存中而不关心块中究竟存放的是什么格式的文件。

cache 在操作系统中指 page cache,中文一般翻译为 “页高速缓存”。页高速缓存是内核实现的磁盘缓存。它主要用来减少对磁盘的 I/O 操作。具体地讲,是通过把磁盘中的数据缓存到物理内存中,把对磁盘的访问变为对物理内存的访问。页高速缓存缓存的是内存页面。缓存中的页来自对普通文件、块设备文件(这个指的就是 buffer cache 呀)和内存映射文件的读写。 页高速缓存对普通文件的缓存我们可以这样理解:当内核要读一个文件(比如 /etc/hosts)时,它会先检查这个文件的数据是不是已经在页高速缓存中了。如果在,就放弃访问磁盘,直接从内存中读取。这个行为称为缓存命中。如果数据不在缓存中,就是未命中缓存,此时内核就要调度块 I/O 操作从磁盘去读取数据。然后内核将读来的数据放入页高速缓存中。这种缓存的目标是文件系统可以识别的文件(比如 /etc/hosts)。 页高速缓存对块设备文件的缓存就是我们在前面介绍的 buffer cahce。因为独立的磁盘块通过缓冲区也被存入了页高速缓存(缓冲区最终是由页高速缓存来承载的)。

到这里我们应该搞清楚了:无论是缓冲区还是页高速缓存,它们的实现方式都是一样的。缓冲区只不过是一种概念上比较特殊的页高速缓存罢了。 那么为什么 free 命令不直接称为 cache 而非要写成 buff/cache? 这是因为缓冲区和页高速缓存的实现并非天生就是统一的。在 linux 内核 2.4 中才将它们统一。更早的内核中有两个独立的磁盘缓存:页高速缓存和缓冲区高速缓存。前者缓存页面,后者缓存缓冲区。当你知道了这些故事之后,输出中列的名称可能已经不再重要了。

free 与 available

在 free 命令的输出中,有一个 free 列,同时还有一个 available 列。这二者到底有何区别? free 是真正尚未被使用的物理内存数量。至于 available 就比较有意思了,它是从应用程序的角度看到的可用内存数量。Linux 内核为了提升磁盘操作的性能,会消耗一部分内存去缓存磁盘数据,就是我们介绍的 buffer 和 cache。所以对于内核来说,buffer 和 cache 都属于已经被使用的内存。当应用程序需要内存时,如果没有足够的 free 内存可以用,内核就会从 buffer 和 cache 中回收内存来满足应用程序的请求。所以从应用程序的角度来说,available = free + buffer + cache。请注意,这只是一个很理想的计算方式,实际中的数据往往有较大的误差。

交换空间(swap space)

swap space 是磁盘上的一块区域,可以是一个分区,也可以是一个文件。所以具体的实现可以是 swap 分区也可以是 swap 文件。当系统物理内存吃紧时,Linux 会将内存中不常访问的数据保存到 swap 上,这样系统就有更多的物理内存为各个进程服务,而当系统需要访问 swap 上存储的内容时,再将 swap 上的数据加载到内存中,这就是常说的换出和换入。交换空间可以在一定程度上缓解内存不足的情况,但是它需要读写磁盘数据,所以性能不是很高。

现在的机器一般都不太缺内存,如果系统默认还是使用了 swap 是不是会拖累系统的性能?理论上是的,但实际上可能性并不是很大。并且内核提供了一个叫做 swappiness 的参数,用于配置需要将内存中不常用的数据移到 swap 中去的紧迫程度。这个参数的取值范围是 0~100,0 告诉内核尽可能的不要将内存数据移到 swap 中,也即只有在迫不得已的情况下才这么做,而 100 告诉内核只要有可能,尽量的将内存中不常访问的数据移到 swap 中。在 ubuntu 系统中,swappiness 的默认值是 60。如果我们觉着内存充足,可以在 /etc/sysctl.conf 文件中设置 swappiness:

代码语言:javascript
复制
vm.swappiness=10

如果系统的内存不足,则需要根据物理内存的大小来设置交换空间的大小。具体的策略网上有很丰富的资料,这里笔者不再赘述。

/proc/meminfo 文件

其实 free 命令中的信息都来自于 /proc/meminfo 文件。/proc/meminfo 文件包含了更多更原始的信息,只是看起来不太直观:

代码语言:javascript
复制
$ cat /proc/meminfo
image
image

有兴趣的同学可以直接查看这个文件。

总结

free 命令是一个既简单又复杂的命令。简单是因为这个命令的参数少,输出结果清晰。说它复杂则是因为它背后是比较晦涩的操作系统中的概念,如果不清楚这些概念,即便看了 free 命令的输出也 get 不到多少有价值的信息。

6:cat /proc/meminfo

image
image

7:cat /proc/cpuinfo

image
image

8:du -sh *

image
image

9: 查看CPU个数

代码语言:javascript
复制
cat /proc/cpuinfo | grep "physical id" | uniq | wc -l

10: 查看CPU核数

代码语言:javascript
复制
cat /proc/cpuinfo | grep "cpu cores" | uniq

11: 查看CPU型号

代码语言:javascript
复制
cat /proc/cpuinfo | grep 'model name' |uniq
image
image

参考:https://blog.csdn.net/Alicia_N/article/details/87604709 https://blog.csdn.net/qq_32670879/article/details/85259916 https://www.cnblogs.com/ultranms/p/9254160.html https://blog.csdn.net/wujizhishui/article/details/89333957

linux下查看某一进程所占用内存的方法

Linux下查看某一个进程所占用的内存,首先可以通过ps命令找到进程id,比如 ps -ef | grep kafka 可以看到kafka这个程序的进程id

image
image

可以看到是2913,现在可以使用如下命令查看内存:

top -p 2913

image
image

这样可以动态实时的看到CPU和内存的占用率,然后按q键回到命令行

也可直接使用ps命令查看: ps -aux | grep kafka

image
image

第一个标注的地方是CPU和内存占用率,后面的943100是物理内存使用量,单位是k,此时kafka大约占用943M内存

还可以查看进程的status文件: cat /proc/2913/status

image
image

VmRSS对应的值就是物理内存占用,大约为943M和刚才一致

另外还可以通过 top 命令动态查看内存占用

通过: ps aux | sort -k4,4nr | head -n 10 查看内存占用前10名的程序

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-11-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • linux查看CPU和内存使用率
    • 1:top
      • 2: vmstat
        • 3:sar
          • 4:dstat
            • 5: free -h
              • linux下free命令详解
              • 输出简介
              • buff/cache
              • free 与 available
              • 交换空间(swap space)
              • /proc/meminfo 文件
              • 总结
            • 6:cat /proc/meminfo
              • 7:cat /proc/cpuinfo
                • 8:du -sh *
                  • 9: 查看CPU个数
                    • 10: 查看CPU核数
                      • 11: 查看CPU型号
                      • 参考:https://blog.csdn.net/Alicia_N/article/details/87604709 https://blog.csdn.net/qq_32670879/article/details/85259916 https://www.cnblogs.com/ultranms/p/9254160.html https://blog.csdn.net/wujizhishui/article/details/89333957
                      • linux下查看某一进程所占用内存的方法
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档