免费注册 查看新帖 |

Chinaunix

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

Windows环境system函数使用的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-10 12:07 |只看该作者 |倒序浏览
在windows下使用的一段Perl代码,实现的功能是从脚本同一路径的config文件中读取要运行的命令。config文件格式为每条要运行的命令行单独成行。不断的读取要运行的命令行,一条一条执行,直到运行时间超过4个小时为止。命令行所用到的exe文件也在脚本的同一路径下。但是脚本跑起来以后,发现一个问题。有时候脚本能正常的跑完4个小时。有时候system会返回错误: Can't spawn "ses_diag -dwnld -d_mcr abc_def_ghi_jkl.bin 400 1" No such file or directory...
可是所有的文件在这个过程中并没有改变位置,为什么有时候成功有时候失败呢

  1. use strict;
  2. use warnings;

  3. use Time::HiRes qw (gettimeofday tv_interval);

  4. my $t0 = 0;
  5. my @commands_list = ();

  6. open CONFIG, "config" or die "Can not open file: config $!\n";
  7. while (<CONFIG>)
  8. {
  9.         chomp;
  10.         push @commands_list, $_;
  11. }
  12. close CONFIG;

  13. $t0 = [gettimeofday];
  14. while (tv_interval($t0, [gettimeofday]) < 4*3600)
  15. {
  16.         foreach (@commands_list)
  17.         {
  18.                 if (system("$_"))
  19.                 {
  20.                         print "Run-in test paused\n";
  21.                          die "Error when executing $_ $!\n";
  22.                 }
  23.         }
  24. }

  25. print "Run-in test for 4 hours completed successfully!\n";
复制代码

论坛徽章:
0
2 [报告]
发表于 2008-06-10 15:19 |只看该作者
这个可能是你的机子在run perl的同时你还在做其他的事情,有时候会造成冲突。
还有就是假如你是从别的机子或者网络上读文件的话也会产生这种情况,当然是网络不稳定的原因咯!~

论坛徽章:
0
3 [报告]
发表于 2008-06-14 19:59 |只看该作者
谢谢楼主。
确实有另外一个程序在对别的磁盘做IO。但这是测试的目的之一。难道没有解决办法吗

论坛徽章:
0
4 [报告]
发表于 2008-06-15 18:40 |只看该作者
呵呵,你可以做一个log file,记录程序运行中的错误返回信息和时间信息,然后对照2个程序,看是否有同时调用同一个文件的问题,这个反正就是冲突啦。。。我们一般在做一些schedual内容的时候一般建议不要同时做其他事情。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP