Chinaunix

标题: Windows环境system函数使用的问题 [打印本页]

作者: hewangping    时间: 2008-06-10 12:07
标题: Windows环境system函数使用的问题
在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";
复制代码

作者: 不死草    时间: 2008-06-10 15:19
这个可能是你的机子在run perl的同时你还在做其他的事情,有时候会造成冲突。
还有就是假如你是从别的机子或者网络上读文件的话也会产生这种情况,当然是网络不稳定的原因咯!~
作者: hewangping    时间: 2008-06-14 19:59
谢谢楼主。
确实有另外一个程序在对别的磁盘做IO。但这是测试的目的之一。难道没有解决办法吗
作者: 不死草    时间: 2008-06-15 18:40
呵呵,你可以做一个log file,记录程序运行中的错误返回信息和时间信息,然后对照2个程序,看是否有同时调用同一个文件的问题,这个反正就是冲突啦。。。我们一般在做一些schedual内容的时候一般建议不要同时做其他事情。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2