博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux top 命令详解
阅读量:6414 次
发布时间:2019-06-23

本文共 2256 字,大约阅读时间需要 7 分钟。

top命令是Linux下使用相当频繁的一个命令,可是有一天突然发现,原来自己对他还是知之甚少(尤其是内存状态这块儿),所以照着man文档和参阅了一些资料,整理如下

执行方式

top -hv | -bcHisSM -d delay -n iterations -p pid [,pid...]

其中:h 输出帮助信息;v输出版本信息,这些命令行选项多数可以通过交互式命令改变top输出,进入top以后按‘h’可现实交互式的命令清单,如下图

-b: ‘批量模式’,用来将输出重定向到指定文件,一般配合-n 指定输出几次统计信息,使用模式

     top -n 3 -b > /tmp/top.tmp

-c: 显示产生进程的完成命令

-H: 线程切换模式,所有独立的线程都会被显示在结果中(以线程为粒度),不加此参数的话,top会以进程为粒度来显示信息

-i: 不显示idled或zombied进程

-s: 安全模式

-S: 累计模式,显示该进程以及他的所有子进程(包括已死的)总共占用的cpu时间

-M: 内存统计相关--显示内存单位(k/M/G)并且显示浮点值(带小数点)的值,如下图

   

-d: 指定刷新时间,默认刷新时间是3s

-n: 执行状态刷新的次数

-p: 指定pid 多个pid以‘逗号’分开,只显示指定pid进程的状态

字段解释:

PID、PPID(父pid)、USER、GROUP、TTY这些字段都是字面意思,就不多说了。着重说一下cpu和内存相关字段的意思

top默认输出如下

按 f 可以进入交互模式,选择更多的输出项,途中红框内为默认显示的项目

我们选择显示更多的cpu和内存相关的项目,

增加显示项目之后,top输出如下

我们以上图输出介绍个字段cpu和内存相关字段含义:

VIRT -- (kb)任务使用的虚拟内存总量,包含所有交换到内存的code、data和shared libraries plus pages.  VIRT = SWAP + RES.只要进程申请了内存,都会计入此值。;例如进程想内核申请了100M内存,此值增加100M,而不管内核实际分配给了多少

RES -- (kb)常驻内存数量,即此任务使用的非交换分区的内存(即物理内存)

SHR -- (kb)任务所使用的共享内存的数量,他只简单的反映了可能与其他进程共享的内存

        SHR是RES中”映射至文件”的物理内存总和。包括:

            程序的代码段。
            动态库的代码段。
            通过mmap做的文件映射。
            通过mmap做的匿名映射,但指明了MAP_SHARED属性。
注:RES要和SHR结合者看,内核把物理内存分为了两部分,一部分是映射至文件的,一部分是没有映射至文件的即匿名内存,完全和共不共享没有关系!
但file_rss为什么叫做shared呢?应该是一种指示性表述,表示这部分内存可能是共享的。但并不代表真正共享了。那么到底哪些计入file_rss?通过查阅相关代码,发现(可能有遗漏):
1、程序的代码段。
2、动态库的代码段。
3、通过mmap做的文件映射。
4、通过mmap做的匿名映射,但指明了MAP_SHARED属性。
5、通过shmget申请的共享内存

注:如何精确的计算进程占用的内存

我们注意到在描述进程信息的proc/<pid>内,有一个smaps文件,里面展示了所有内存段的信息,其中有Shared_Clean Shared_Dirty Private_Clean Private_Dirty:几个字段。

统计smaps文件内所有段的Shared_*值的总和就是进程准确的共享内存数量!
统计smaps文件内所有段的Private_*值的总和就是进程准确的独占内存数量!

S -- 进程状态

%CPU -- 自上次刷新以来该进程占用的总cpu时间的百分比.在一个true SMP environment(真正的对称多处理器环境)下,如果’Irix mode’关闭(默认为打开状态),top将运行在’Solaris mode’,此模式下一个任务的cpu使用率将会被除以CPU数量之后显示。通过 I 命令可以交互式关闭/打开此模式 

%MEM -- 任务使用物理内存的百分比

TIME+  -- (ms)和time类似,以毫秒为单位显示

P -- 上一次用到的cpu,在‘多cpu环境下’显示该进程上一次使用的cpu节点

SWAP -- (kb)任务的总虚拟内存镜像被换到交换分区的部分。看到一篇博客说:这里应该是改进程使用过的swap的量

另:top汇总部分swap信息里面cached的部分表示的是曾经换入swap后又被换出,但是swap里的内容还未被覆盖的部分

Swap: 32767992k total,   986504k used, 31781488k free,  2740516k cached

TIME -- (s)任务自启动以来占用的CPU总时间。如果’Cumulative mode’(累计模式,默认关闭)打开,将显示此简称以及此进程的子进程(包括已死的)总共占有的cpu时间。累计模式可以通过命令行和交互式两种模式打开

例如下图:TIME+表示9517s33ms;TIME 表示158m37s

CODE --  (kb)用来‘执行程序代码’的物理内存/存放进程代码的物理内存

DATA -- (kb)Data+Stack size。进程占用实体内存中的非程序码部份的大小

COMMAND -- 启动进程的命令

转载地址:http://qobra.baihongyu.com/

你可能感兴趣的文章
Android Studio自带的抓图和录像功能
查看>>
教妹学 Java:动态伴侣 Groovy
查看>>
第三周作业
查看>>
对象.原型链,函数.原型对象
查看>>
动态 K th
查看>>
MVC 中引入Jquery文件的几种方法
查看>>
servlet容器开发要点
查看>>
[转载]使用Cufon技术实现Web自定义字体
查看>>
dede全功能手册V5.3
查看>>
架构师入门ing
查看>>
[UOJ218]火车管理
查看>>
Android -- 自定义View(一)
查看>>
dp - HNU 13404 The Imp
查看>>
day29 类中的内置函数方法 __str__ __repr__ __call__ isinstance() issubclass()
查看>>
富文本编辑器 CKeditor 配置使用+上传图片
查看>>
Ignatius and the Princess I
查看>>
mysql
查看>>
一些比较神奇的思路
查看>>
[网络流24题-13]餐巾计划问题
查看>>
flex自定义preloader预加载进度条
查看>>