当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 14 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 11:36 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
RT,需要写一个bash脚本,运行若干小型外部程序(每个运行时间不超过1s,甚至0.00x秒就运行结束了),并监控运行时间和使用内存
我看了/usr/bin/time的手册,它号称可以监控时间和内存
引用:
K Average total (data+stack+text) memory use of the pro-
cess, in Kilobytes.

但是运行结果如下:
代码:
lonelycorn:~/silica/silica$ /usr/bin/time -f "MEM:%K\nTIM:%E" sleep 1
MEM:0
TIM:0:01.00

时间是有了,但是怎么监控它使用的内存大小(或者虚拟内存)?

ps太慢了,它还没扫描完我运行的程序就结束了。
top也是这样的。


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 11:38 
头像

注册: 2005-08-14 21:55
帖子: 58428
地址: 长沙
送出感谢: 4
接收感谢: 272
这不会。可为什么要监视这个呢?


_________________
● 鸣学


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 11:39 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
信息学竞赛(或ACM)用(测试程序运行结果,对使用时间和内存有严格要求)。我交题前要先看看是不是超过要求了。


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
4 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 12:06 
头像

注册: 2005-08-14 21:55
帖子: 58428
地址: 长沙
送出感谢: 4
接收感谢: 272
那估计软件内部取得参数了。外部监视内存,本来就是儿戏,谁知道被监视的软件,会不会突然申请一个巨大的堆。


_________________
● 鸣学


页首
 用户资料  
 
5 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 12:28 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
eexpress 写道:
那估计软件内部取得参数了。外部监视内存,本来就是儿戏,谁知道被监视的软件,会不会突然申请一个巨大的堆。

此话怎讲?对于我们使用的程序而言一般情况下程序开始运行就自动申请内存(很少使用指针动态申请)
另:“那估计软件内部取得参数了”怎么解释?


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
6 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 12:44 
头像

注册: 2005-08-14 21:55
帖子: 58428
地址: 长沙
送出感谢: 4
接收感谢: 272
估计没接触过汇编。
你软件里面,启动或者结束的时候,调用shell算了。取得id,执行
ps -e -o pid,%mem,command,rss,vsz
要看哪个,自己选择。输出到文件。


_________________
● 鸣学


页首
 用户资料  
 
7 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 12:48 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
我本来是打算这么写的,但是fork来fork去的在ps开始之前程序已经结束了。


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
8 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-05 12:52 

注册: 2006-09-11 22:47
帖子: 2841
送出感谢: 0 次
接收感谢: 4
lonelycorn 写道:
RT,需要写一个bash脚本,运行若干小型外部程序(每个运行时间不超过1s,甚至top也是这样的。


用 valgrind ,

sudo apt-get install valgrind

然后 valgrind -v 后面带你的程序就行。

注意:valgrind 会在运行期间动态把你的程序连接到 libc6-dbg 库,所以效率要慢一些,监控时间不太行,监控内存是没有问题的。

具体给出的信息比较多,你可以自己仔细查看一下。


页首
 用户资料  
 
9 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-07 9:32 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
这个valgrind是一个daemon类的后台运行的服务?
其实我想在脚本里面写一个后台运行的程序段一直ps,直到ps到我的程序运行。我试了这个方法,但是效果不理想
代码:
while :
do
  if ps -eo pid,rss,comm ${exe} then break
  {这里还有个计数器,防止总也ps不到,但是理论上说应该不用的}
done &

exe是程序名


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
10 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-07 17:45 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
顶起来
对上面的代码没有什么意见或建议吗?


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
11 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-12 22:46 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
顶起。
顺便问一下,Linux中有没有一个有关创建进程,获得进程信息(pid,内存,运行等级之类的)的库?M$的Window$就有。
还有,怎么在脚本中执行命令时获得该命令的pid?


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
12 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-12 22:49 
头像

注册: 2007-11-19 21:51
帖子: 6956
地址: 成都
送出感谢: 0 次
接收感谢: 4
$!上一条命令的id, $$脚本的id


页首
 用户资料  
 
13 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-13 8:00 
头像

注册: 2007-05-20 18:44
帖子: 438
地址: 唐山,河北,中国
送出感谢: 0 次
接收感谢: 1
no no no这个我也知道,我想问的是
怎么在脚本内运行一个命令时知道命令的pid
比如这样的脚本
代码:
#!/bin/bash
sleep 100000000

怎么获得sleep的pid?


_________________
我逗无了奈了……
HP的本跑ubuntu还得把我折腾死。
显卡、无线/有线网卡、声卡、键盘……
代码:
while :
do
  work_hard
done


页首
 用户资料  
 
14 楼 
 文章标题 : Re: 如何监控运行时间很短的程序的内存使用?
帖子发表于 : 2009-03-13 9:56 
头像

注册: 2006-04-12 20:05
帖子: 8495
地址: 杭州
送出感谢: 0 次
接收感谢: 8
还是在自己的程序里输出自己的状态比较靠谱。


_________________
关注我的blog: ε==3


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 14 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译