仓酷云
标题:
来一发Linux中怎样晓得谁在切换历程
[打印本页]
作者:
分手快乐
时间:
2015-1-16 10:55
标题:
来一发Linux中怎样晓得谁在切换历程
功能实在太强了,在配合exec参数或者通过管道重定向到xargs命令和grep命令,可以完成非常复杂的操作,如果同样的操作用图形界面的工具来完成,恐怕要多花十几陪的时间。
我们在做Linux服务器的时分常常会必要晓得谁在做历程切换,甚么缘故原由必要做历程切换。由于历程切换的价值很高,我给出一个LMbench测试出来的数字:
ContextswitchingCtimesinmicrosecondsCsmallerisbetter
――――――――――――――――――――――――-
HostOS2p/0K2p/16K2p/64K8p/16K8p/64K16p/16K16p/64K
ctxswctxswctxswctxswctxswctxswctxsw
―――――――-――――――――――――-――-
my174.cm4Linux2.6.18-6.11007.02006.11008.74007.72008.960009.62000
在我的很高真个服务器上,历程切换的开支在8us摆布,这个相对高功能的服务器是不成承受的,以是我们要在一个工夫片内尽量的多办事情,而不是把工夫华侈在无谓的切换上。
猎奇害逝世猫,我们来查询拜访下谁在切换我们的历程:
viewsourceprint?[root@my174admin]#dstat1
----total-cpu-usage-----dsk/total--net/total----paging-----system--
usrsysidlwaihiqsiq|readwrit|recvsend|inout|intcsw
00100000|00|796B1488B|00|1004128
00100000|00|280B728B|00|1005114
00100000|00|280B728B|00|1005128
00100000|00|280B728B|00|1005114
00100000|0320k|280B728B|00|1008143
...
我们能够看到csw的数量是120/S,可是dstat大概vmstat相似的工具并没有告知我们谁在干好事。好吧!我们本人下手行吧。
祭出我们心爱的systemtap!
viewsourceprint?[root@my174admin]#cat>cswmon.stp
#!/usr/bin/envstap
#
#
globalcsw_count
globalidle_count
probescheduler.cpu_off{
csw_count[task_prev,task_next]++
idle_count+=idle
}
functionfmt_task(task_prev,task_next)
{
returnsprintf("%s(%d)->%s(%d)",
task_execname(task_prev),
task_pid(task_prev),
task_execname(task_next),
task_pid(task_next))
}
functionprint_cswtop(){
printf("%45s%10s
","Contextswitch","COUNT")
foreach([task_prev,task_next]incsw_count-limit20){
printf("%45s%10d
",fmt_task(task_prev,task_next),csw_count[task_prev,task_next])
}
printf("%45s%10d
","idle",idle_count)
deletecsw_count
deleteidle_count
}
probetimer.s({GetProperty(Content)}){
print_cswtop()
printf("----------------------------------------------------
12下一页
要明白学好linux不是一件一蹴而就的事,一定要能坚持使用它,特别是在使用初期。
作者:
分手快乐
时间:
2015-1-16 12:24
标题:
来一发Linux中怎样晓得谁在切换历程
虽然Linux桌面应用发展很快,但是命令在Linux中依然有很强的生命力。Linux是一个命令行组成的操作系统,精髓在命令行。
----------\n")</P> }
CTRL+D
这个剧本会每隔设定的工夫打印出TOP20切换最多的历程和他的pid,我们来看下了局把:
viewsourceprint?[root@my174admin]#stapcswmon.stp5
ContextswitchCOUNT
swapper(0)->systemtap/11(908)500
systemtap/11(908)->swapper(0)498
swapper(0)->fct1-worker(2492)50
fct1-worker(2492)->swapper(0)50
swapper(0)->fct0-worker(2191)50
fct0-worker(2191)->swapper(0)50
swapper(0)->bond0(3432)50
bond0(3432)->swapper(0)50
stapio(879)->swapper(0)26
swapper(0)->stapio(879)25
stapio(879)->swapper(0)19
swapper(0)->stapio(879)17
swapper(0)->watchdog/9(31)5
watchdog/9(31)->swapper(0)5
swapper(0)->mysqld(18346)5
mysqld(18346)->swapper(0)5
swapper(0)->watchdog/13(43)5
watchdog/13(43)->swapper(0)5
swapper(0)->watchdog/14(46)5
watchdog/14(46)->swapper(0)5
idle859
--------------------------------------------------------------
...
我们能够看到历程从那里切换到那里,而且产生了几次,最初一行,我打印出来idle的次数,也就是说这时候候体系没啥事变做,就切换到idle(0)这个历程往歇息往了。
经由过程下面的查询拜访,我们会很分明的懂得到我们体系的开支产生在那边,便利我们定位成绩
</p>
上一页12
Linux的常用命令find,察看man文档,初学者一定会觉得太复杂而不原意用,但是你一旦学会就爱不释手。
作者:
兰色精灵
时间:
2015-1-18 15:26
选择交流平台,如QQ群,网站论坛等。
作者:
精灵巫婆
时间:
2015-1-27 09:39
随着IT从业人员越来越多,理论上会有更多的人使用Linux,可以肯定,Linux在以后这多时间不会消失。
作者:
莫相离
时间:
2015-2-5 12:29
虽然大家都比较喜欢漂亮的mm,但是在学 linux 的过程中,还是要多和“男人”接触一下:P 遇到问题的时候,出来看说和上网查之外,就是要多用 linux 下的 man 命令找找帮助。
作者:
活着的死人
时间:
2015-2-11 21:37
随着Linux技术的更加成熟、完善,其应用领域和市场份额继续快速增大。目前,其主要应用领域是服务器系统和嵌入式系统。然而,它的足迹已遍布各个行业,几乎无处不在。
作者:
分手快乐
时间:
2015-3-2 21:08
我想即使Linux高手也很难快速准确精练的回答你。
作者:
老尸
时间:
2015-3-11 07:40
请问谁有Linux的学习心得的吗?简单的说说?
作者:
admin
时间:
2015-3-18 04:27
掌握在Linux系统中安装软件,在安装Linux工具盘后大致日常所需的软件都会有,一般网络提供下载的软件都会有安装说明。
作者:
透明
时间:
2015-3-25 16:50
让我树立了很大的信心学好这门课程,也学到了不少专业知识和技能。?
欢迎光临 仓酷云 (http://ckuyun.com/)
Powered by Discuz! X3.2