【Linux系列-1】top命令详解


KiB Mem : 16267784 total,  5136976 free,  9050312 used,  2080496 buff/cache



第四行描述的是系统的内存使用情况(以kb为单位):

  • 16267784 total — 物理内存总量

  • 5136976 used — 使用中的内存总量

  • 9050312 free — 空闲内存总量

  • 2080496 buff/cache — 缓存的内存量

1.5 第五行



KiB Swap:  6160380 total,  6005320 free,   155060 used.  5676356 avail Mem 



第五行描述的是交换分区情况:

  • 6160380 total — 交换区总量

  • 155060 used — 使用的交换区总量

  • 6005320 free — 空闲交换区总量

  • 5676356 avail Mem — 可用的交换区总量

2 输出项目说明

===================================================================

在默认情况下,仅显示比较重要的 PIO、USERPR、NI、VIRT、RES、SHR、S、%CPU、%MEMTIME+、COMMAND列。

要想展示隐藏项,按 f 键进入选择界面,左侧有 * 号的表示该项是展示状态,通过方向键上下移动到某项,按 d 键可以改变该项的展示状态,然后按【ESC】或【q】键退出返回top界面。


* PID     = Process Id          

* USER    = Effective User Name 

* PR      = Priority            

* NI      = Nice Value          

* VIRT    = Virtual Image (KiB) 

* RES     = Resident Size (KiB) 

* SHR     = Shared Memory (KiB) 

* S       = Process Status      

* %CPU    = CPU Usage           

* %MEM    = Memory Usage (RES)  

* TIME+   = CPU Time, hundredths

* COMMAND = Command Name/Line   

  PPID    = Parent Process pid  

  UID     = Effective User Id   

  RUID    = Real User Id        

  RUSER   = Real User Name      

  SUID    = Saved User Id       

  SUSER   = Saved User Name     

  GID     = Group Id            

  GROUP   = Group Name          

  PGRP    = Process Group Id    

  TTY     = Controlling Tty     

  TPGID   = Tty Process Grp Id  

  SID     = Session Id          

  nTH     = Number of Threads   

  P       = Last Used Cpu (SMP) 

  TIME    = CPU Time            

  SWAP    = Swapped Size (KiB)  

  CODE    = Code Size (KiB)     

  DATA    = Data+Stack (KiB)    

  nMaj    = Major Page Faults   

  nMin    = Minor Page Faults   

  nDRT    = Dirty Pages Count   

  WCHAN   = Sleeping in Function

  Flags   = Task Flags <sched.h>

  CGROUPS = Control Groups      

  SUPGIDS = Supp Groups IDs     

  SUPGRPS = Supp Groups Names   

  TGID    = Thread Group Id     

  ENVIRON = Environment vars    

  vMj     = Major Faults delta  

  vMn     = Minor Faults delta  

  USED    = Res+Swap Size (KiB) 

  nsIPC   = IPC namespace Inode 

  nsMNT   = MNT namespace Inode 

  nsNET   = NET namespace Inode 

  nsPID   = PID namespace Inode 

  nsUSER  = USER namespace Inode

  nsUTS   = UTS namespace Inode 



各列的含义:

| 序号 | 列名 | 含义 |

| — | — | — |

| a | PID | 进程ID |

| b | PPID | 父进程ID |

| c | RUSER | 真实用户名 |

| d | UID | 进程所有者的用户id |

| e | USER | 进程所有者的用户名 |

| f | GROUP | 进程所有者的组名 |

| g | TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |

| h | PR | 优先级 |

| i | NI | nice值。负值表示高优先级,正值表示低优先级 |

| j | P | 最后使用的CPU,仅在多CPU环境下有意义 |

| k | %CPU | 上次更新到现在的CPU时间占用百分比 |

| l | TIME | 进程使用的CPU时间总计,单位秒 |

| m | TIME+ | 进程使用的CPU时间总计,单位1/100秒 |

| n | %MEM | 进程使用的物理内存百分比 |

| o | VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |

| p | SWAP | 进程使用的虚拟内存中,被换出的大小,单位kb。 |

| q | RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |

| r | CODE | 可执行代码占用的物理内存大小,单位kb |

| s | DATA | 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb |

| t | SHR | 共享内存大小,单位kb |

| u | nFLT | 页面错误次数 |

| v | nDRT | 最后一次写入到现在,被修改过的页面数。 |

| w | S | 进程状态:D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程 |

| x | COMMAND | 命令名/命令行 |

| y | WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |

| z | Flags | 任务标志,参考 sched.h |

3 命令参数

=================================================================

top命令可以后缀不同的参数,从而实现特定目的。

3.1 参数详解


  1. -b 批次模式运行,通常用来将top的输出结果传送给其他程式或储存成文件。

  2. -d 指定每两次屏幕信息刷新之间的时间间隔。可以使用s交互命令来改变之。

  3. -p 监控指定进程。监控多个进程时,进程ID之间以逗号分隔,只能在命令行下使用。

  4. -q 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。

  5. -S 指定累计模式

  6. -s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。

  7. -i 使top不显示任何闲置或者僵死进程。

  8. -c 显示整个命令行而不只是显示命令名

  9. -n top命令运行n次,一般与-b搭配使用

  10. -H 显示线程,当这个设定开启时, 将显示所有进程产生的线程。

  11. -I 显示空闲的进程。

3.2 使用示例


  • top -b -d 2 -n 5 -c > result.txt:每2s监控一次,监控5次,并将结果保存到文件中。

  • top -d 2:每隔2秒显式所有进程的资源占用情况

  • top –c:每隔5秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)

  • top -p 12345 -p 6789:每隔5秒显示pid是12345和pid是6789的两个进程的资源占用情况

  • top -d 2 -c -p 123456 :每隔2秒显示pid是12345的进程的资源使用情况,并显式该进程启动的命令行参数

  • top -p -H:显示一个进程中各个线程CPU的占用率

4 交互命令

=================================================================

为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。

本份面试集锦涵盖了

  • 174 道运维工程师面试题
  • 128道k8s面试题
  • 108道shell脚本面试题
  • 200道Linux面试题
  • 51道docker面试题
  • 35道Jenkis面试题
  • 78道MongoDB面试题
  • 17道ansible面试题
  • 60道dubbo面试题
  • 53道kafka面试
  • 18道mysql面试题
  • 40道nginx面试题
  • 77道redis面试题
  • 28道zookeeper

总计 1000+ 道面试题, 内容 又全含金量又高

  • 174道运维工程师面试题

1、什么是运维?

2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

3、现在给你三百台服务器,你怎么对他们进行管理?

4、简述raid0 raid1raid5二种工作模式的工作原理及特点

5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

7、Tomcat和Resin有什么区别,工作中你怎么选择?

8、什么是中间件?什么是jdk?

9、讲述一下Tomcat8005、8009、8080三个端口的含义?

10、什么叫CDN?

11、什么叫网站灰度发布?

12、简述DNS进行域名解析的过程?

13、RabbitMQ是什么东西?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
?

14、讲一下Keepalived的工作原理?

15、讲述一下LVS三种模式的工作过程?

16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

17、如何重置mysql root密码?

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值