linux抓取top命令中数据的方法

Posted Young233

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux抓取top命令中数据的方法相关的知识,希望对你有一定的参考价值。

top在linux中是一个非常直观的命令,可以清晰地看到各进程对资源的使用情况。

 

但是如果你想从top命令展示中提取某些数据出来,如果想当然地使用这句命令:

top|grep xxx

就会被卡住,欲哭无泪。

 

我们不妨查一下top这个命令,看看是否有其他办法来把数据抓出来。

 

首先简单了解一下top这个命令。

 

top是linux的一个性能分析工具,类似于windows的任务管理器。其最大特点有两个:动态、直观地显示进程占用资源情况。

执行top的时候,会在前台默认打开一个terminal,可使用q来退出。

例如:

 

上面的图中,有很多有用的信息:

1. 可以看到uptime、1min 5min 15min的负载
2. 可以看到总任务数、在跑任务数、停止任务数、僵尸任务数
3. 可以看到user数
4. 可以看到总的cpu负载情况
5. 可以看到总的内存和swap使用情况,以kb为单位
6. 各个进程使用系统资源的情况

 

上面的各列分别指:

PID: 进程号
USER: 启动进程的用户
PR: 优先级
NI: 谦让级
VIRT: 虚拟内存占用
RES: 进程使用的、未被换出的物理内存大小
SHR: 共享内存大小,单位kb
S: 进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
%CPU: 上次更新到现在的CPU时间占用百分比
%Mem: 物理内存占用百分比
TIME+: 进程启动时间
COMMAND: 命令名

 

而这个命令也有一些参数,具体可以看下边:

-b: 批处理
-c: 显示完整的命令
-l:忽略失效进程
-s: 保密模式
-n 数字: 显示次数,后加
-u 用户名: 显示某用户下的进程情况
-p 进程号: 指定进程

 

top还有一些交互命令,在前置页面使用,十分方便:

h: 显示帮助菜单
k: 杀死一个进程
i: 忽略僵尸进程
P: 按照CPU占用进行排序
M: 按照内存占用进行排序
T: 根据时间/累计时间进行排序
W: 将结果保存到~/.toprc文件

 

好了,介绍了一圈之后,到了本文的重点了。如果我要抓出mysql进程,查看其性能情况并取数,可使用以下两种方法:

top -u mysql -n 1|grep mysqld|awk \'{print $9}\'   #取CPU占用数据
top -u mysql -n 1|grep mysqld|awk \'{print $10}\'  #取内存占用数据

或者:

top -b -n 1|grep mysql|awk \'{print $9}\'    #取CPU占用数据
top -b -n 1|grep mysql|awk \'{print $10}\'   #取内存占用数据

而抓取数据只是前置步骤,后续可以使用此数据进行各种后续操作。

以上是关于linux抓取top命令中数据的方法的主要内容,如果未能解决你的问题,请参考以下文章

在linux命令行环境下如何抓取网络数据包?

Linux中系统检测工具top命令

Python爬虫编程思想(86):项目实战--抓取豆瓣音乐排行榜

Python爬虫编程思想(86):项目实战--抓取豆瓣音乐排行榜

linux之top命令

转载 linux常用的监控命令工具