免费注册 查看新帖 |

Chinaunix

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

PERL文件监控导至CPU很高 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-06-24 10:01 |只看该作者 |倒序浏览
代码如下:

open (tlog,"<c:\\tlog1.log") or die $!;
while(1){
  my $in = <tlog>;
  print $in;
}

winodws XP 操作系统 .CPU:1.83GHz
只有一运行以上代码,CPU就马上增长到50%以上,
我是双核CPU,基本上可以看到其中一核已全部占完。


请问,有没有更好的方法啊,这CPU也太高了

论坛徽章:
0
2 [报告]
发表于 2011-06-24 10:18 |只看该作者
OK.问题已解决,参考了别人的脚本。

在while循环的最后加sleep 1;
OK..  运行时CPU很低。

论坛徽章:
0
3 [报告]
发表于 2011-06-24 10:23 |只看该作者
  1. open (tlog,"<c:\\tlog1.log") or die $!;
  2. while(1){
  3.   my $in = <tlog>;
  4.   print $in;
  5. }
复制代码


你这个可谓经典代码了,它首先是个crazy loop,CPU不涨才怪。。
为什么不正儿八经写呢?

  1. open my $tlog,"<","xxx.file" or die $!;
  2. while(<$tlog>) {
  3.     print;
  4. }
  5. close $tlog;
复制代码

论坛徽章:
0
4 [报告]
发表于 2011-06-24 10:25 |只看该作者
大日志文件读的太快了CPU内存吃不消

Perl 还有个很好的函数seek你可以试试,一次读指定字节

论坛徽章:
0
5 [报告]
发表于 2011-06-24 10:32 |只看该作者
所谓的文件监控就是打印出来么?

论坛徽章:
0
6 [报告]
发表于 2011-06-24 10:34 |只看该作者
回复 4# newstudent2011


   
    靠,注册时间够新的...

论坛徽章:
0
7 [报告]
发表于 2011-06-24 16:18 |只看该作者
俺是菜鸟,各位前辈请多多指教。

以上代码只是一个测试,


open (tlog,"<c:\\tlog1.log") or die $!;
seek(tlog,0,2);
while(1){
  my $in = <tlog>;
  if( $in XXXX){ XXXXXXXX};
  sleep 1;    #  加上CPU下来了,只有3%左右
}

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
8 [报告]
发表于 2011-06-24 18:18 |只看该作者
太牛了啊!!!佩服佩服!

论坛徽章:
0
9 [报告]
发表于 2011-06-24 19:38 |只看该作者
That is classic and very old method for tail -f in perl!!!
my $file = 'test.log';
open (LOG, $file) or die $!;
for (;;) {
    print <LOG>;
    sleep 1;
    seek (LOG, 0, 1);
}


See perldoc perlfaq5, man pause

论坛徽章:
0
10 [报告]
发表于 2011-06-25 12:26 |只看该作者
本帖最后由 newstudent2011 于 2011-06-25 12:37 编辑

这么大大文件不知你打印有什么意义?

如果你是想日志超过字节分段转储,读大文件尽量不要用while,可以试试改变$/

  1. undef $/;
  2. open FILE, "123.log";
  3.    $content = <FILE>;
  4.    close FILE;
  5. $/="\n";
  6. open (FILE,">bak.log");
  7. print FILE  $content;
  8. close FILE;

复制代码
# 测试结果,100兆大文件瞬间处理完毕,CPU 来不及高就结束了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP