• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

寻找UNIX中CPU的“消耗大户”

发布: 2007-6-08 22:43 | 作者: seanhe | 来源: | 查看: 21次 | 进入软件测试论坛讨论

领测软件测试网
(石立 )

多用户的UNIX计算机系统在运行过程中,有时会感觉到运算速度突然慢下来,有时甚至连从键盘输入字符也得过好久才会有反应。有经验的人一定会知道,这时计算机中一定在运行一个非常耗费CPU的进程。这样的进程有时是某个人在执行一个很占CPU的程序,有时则可能是系统中出了意外情况,系统本身在进行处理。无论是哪种情况,系统管理员都应及时找出这样的进程,并做出相应的处理。 

UNIX虽然提供了“acct”等一系列记账程序,但这些程序只能在进程结束后才能显示运行时间和占用CPU时间等信息,不能实时计算单位时间内哪一个进程占用CPU时间最多。 

为此本人用shell语言编写了一段程序,利用UNIX提供的一些实用程序,实现了上述功能。 

此段程序中包含 ps、cut、diff等UNIX实用程序,下面先简单介绍一下这些实用程序的功能。 

 ps: 用来显示当前系统中进程的有关信息。用 -e 参数则显示系统中所有进程的信息。使用 -f 参数则显示各进程完整的信息; 
cut: 用于以列为单位对文件进行剪裁。参数“-c -15,33-”表示把输入文件每行前15个字符及第33个字符以后直到行尾的所有字符放入输出文件; 
echo: 用于向屏幕上显示提示信息; 
sleep: 可以让 shell 程序等待若干秒,然后再执行后面的语句; 
diff: 用于对两个文件进行比较,不同之处则显示出来; 
sort: 可对文件中的各行进行排序,排序结果可显示出来; 
grep: 可用来找出文件中满足一定条件的行。参数“^”表示找出第一列为空格的各行; 
|: 为管道的符号,可实现把前面命令的输出作为后面命令输入的作用,这样就可省略生成中间文件的步骤,提高执行效率; 
>: 表示对输出进行重定向,把本来应显示在屏幕上的东西输出到文件中。 


程序内容如下: 

 

ps -ef|cut -c -15,33->tt1
echo Please wait a while...
sleep 20
ps -ef|cut -c -15,33->tt2
echo Attention !
echo 
diff tt1 tt2|cut -c 2->tt3
sort tt3|grep '^ '|cut -c -83|grep -v 0:00
echo 
echo That is ok!
rm tt1 tt2 tt3
  


 

程序说明 


程序首先取得系统中所有进程的信息并把其中有用的字段放入临时文件tt1中。接着让程序等待20秒(时间可依具体情况进行调整)。 

然后再一次取得所有进程的信息,并把所有的字段放入临时文件tt2 中。 

对两个临时文件进行比较,找出20秒前后信息不同的那些进程(其中就有消耗CPU时间已经发生了变化的进程)。 

去掉进行比较时产生的“>”和“<”,把结果放入临时文件tt3中。 

对tt3中的内容进行排序,把耗费CPU时间发生变化的同一进程的前后信息排在一起。grep“^”则是用来去掉执行此shell程序时产生的一些中间命令进程的信息。 

再用cut删去每行中过长的进程信息,使输出更加清晰。而grep -v 0:00 则用来去掉20秒前后只出现一次的进程。程序执行至此,在20秒前后耗费CPU时间不同的进程就显示在屏幕上了,从中可以很容易地找出所要找的进程。最后为了不在系统中留下无用的垃圾文件,还要把三个临时文件全都删去。

 liujinbo 回复于:2003-04-01 12:37:11
看不出来!

 一生不变 回复于:2003-04-01 12:54:48
比较完之后的信息看不明白
能举例说明吗?

 小跑 回复于:2003-04-01 20:33:48
关注ing

 lqy009 回复于:2003-04-01 21:55:19
多谢老大,则个东东,我在自己主机上试了一下,很好!比偶自己用ps 命令找要方便多了,thank you very much !(献上无数高帽···)

 dengzuy 回复于:2003-04-04 21:32:53
能解释一下怎么分析结果吗?

 dengzuy 回复于:2003-04-09 14:59:28
请高手解释一下???
Attention !

--
--
--
--
     root   461        ?    00:01:23 oninit
     root   461        ?    00:01:26 oninit
04,205c204,211
3c53
74c174
92c192

That is ok

 angel518 回复于:2003-04-09 19:01:33
no time to see!

 peace_chh 回复于:2003-04-18 15:22:39
没有必要用文件TT1,TT2,TT3!如果我没有记错执行SHELL时,要生成临时文件,可以使用&&就可以了!

 maomaojia 回复于:2003-04-24 12:58:15
大侠们,偶是菜鸟,这程序咋调用啊?谢拉!
 :D

 level 回复于:2004-02-27 18:54:35
8错

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网