免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 9267 | 回复: 7
打印 上一主题 下一主题

[系统管理] Top命令显示的内容是如何实现的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-10-28 11:14 |只看该作者 |倒序浏览
这是一道面试题,楼主被问到top显示的内容是如何实现的?

想了半天没想出来,请教下大神们,谢谢。

我去面试的是运维部门而非开发部门!

论坛徽章:
2
双鱼座
日期:2014-08-27 10:07:04巳蛇
日期:2014-09-26 11:49:06
2 [报告]
发表于 2014-10-28 12:46 |只看该作者
应该是每隔一段时间读取/proc/stat文件里的数据再整理得到。
搜到两篇文章觉得讲的不错。
第一个是从运维角度分析的,第二个是从内核角度分析的
http://blog.chinaunix.net/uid-20057401-id-1979032.html
http://ilinuxkernel.com/?p=333

论坛徽章:
0
3 [报告]
发表于 2014-10-28 13:02 |只看该作者
本帖最后由 老子是容嬷嬷 于 2014-10-28 13:04 编辑

应该是每隔一段时间读取/proc/stat文件里的数据再整理得到。
搜到两篇文章觉得讲的不错。
第一个是从运维角度分析的,第二个是从内核角度分析的
http://blog.chinaunix.net/uid-20057401-id-1979032.html
http://ilinuxkernel.com/?p=333

    应该不是每隔一段时间去读吧吧,top显示的内容都是实时的,动态的,每隔一段时间去读,岂不是不准了。

论坛徽章:
13
技术图书徽章
日期:2014-04-29 14:15:42IT运维版块每日发帖之星
日期:2015-12-12 06:20:00IT运维版块每日发帖之星
日期:2015-08-30 06:20:00IT运维版块每日发帖之星
日期:2015-08-24 06:20:00IT运维版块每日发帖之星
日期:2015-08-02 06:20:002015年亚洲杯之澳大利亚
日期:2015-04-03 15:03:12申猴
日期:2015-03-20 09:00:292015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15季节之章:冬
日期:2015-01-20 17:08:47双子座
日期:2014-11-21 16:30:31技术图书徽章
日期:2014-07-11 16:29:08
4 [报告]
发表于 2014-10-28 14:47 |只看该作者
个人觉得应该从top的源代码来分析下比较清楚点

论坛徽章:
2
双鱼座
日期:2014-08-27 10:07:04巳蛇
日期:2014-09-26 11:49:06
5 [报告]
发表于 2014-10-28 15:39 |只看该作者
本帖最后由 番茄罐头 于 2014-10-28 15:42 编辑

回复 3# 老子是容嬷嬷

top不是实时的。
第一篇文章里说的很清楚了。
   
cat /proc/stat
会看到下面的结果
cpu 432661 13295 86656 422145968 171474 233 5346
cpu0 123075 2462 23494 105543694 16586 0 4615

PU 以及CPU0、CPU1、CPU2、CPU3每行的每个参数意思(以第一行为例)为:
参数 解释
user (432661) 从系统启动开始累计到当前时刻,用户态的CPU时间(单位:jiffies) ,不包含 nice值为负进程。1jiffies=0.01秒
nice (13295) 从系统启动开始累计到当前时刻,nice值为负的进程所占用的CPU时间(单位:jiffies)
system (86656) 从系统启动开始累计到当前时刻,核心时间(单位:jiffies)
idle (42214596 从系统启动开始累计到当前时刻,除硬盘IO等待时间以外其它等待时间(单位:jiffies)
iowait (171474) 从系统启动开始累计到当前时刻,硬盘IO等待时间(单位:jiffies) ,
irq (233) 从系统启动开始累计到当前时刻,硬中断时间(单位:jiffies)
softirq (5346) 从系统启动开始累计到当前时刻,软中断时间(单位:jiffies)

stat文件中的信息是实时的,每0.01秒刷新一次。
而top默认每隔3秒从stat中取出当前的值记录下来。
那么CPU利用率可以使用以下两个方法。先取两个采样点,然后计算其差值:

cpu usage=(idle2-idle1)/(cpu2-cpu1)*100
cpu usage=[(user_2 +sys_2+nice_2) - (user_1 + sys_1+nice_1)]/(total_2 - total_1)*100
对于这种采点的计算方式,采点的间隔时间越长,结果越准确

论坛徽章:
0
6 [报告]
发表于 2014-10-28 19:44 |只看该作者
可以找找关于T命令的说明及工作原理等的资料看看

论坛徽章:
0
7 [报告]
发表于 2014-10-29 08:16 |只看该作者
回复 1# 老子是容嬷嬷


    哥们,还问道啥问题?能讲讲不

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
8 [报告]
发表于 2014-10-29 13:47 |只看该作者
回复 3# 老子是容嬷嬷


    你觉得电影是连续的,其实它不是
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP