2013-03-15

程序並行運行測試



配合測試需在觀察在同個時間點並行執行15個程序,且程序中皆須要有I/O的行為,原本想使用Perl的Thread Function,但其實shell就提供好用的pipe模式,下列三個情境可參考:

一、若程序相關,用管道便可以完成
cmd1 | cmd2 |...| cmdN

二、若完全無關聯,可以用job的方式
cmd1&; cmd2& ...& cmdN&

三、用script也可以,但下列的方式僅限於兩個!
perl -e 'fork() ? `cmd1` : `cmd2`'

而這次是採用第一個情境,並透過dd來產生1GB的檔案,產生檔名的方式是利用亂數來命名,簡易的Script如下所示:


#!/usr/bin/perl

my $rand=rand 3;
`dd if=/dev/zero of="$rand"_file_1GB bs=1m count=1k`;



當執行完成後,檔案名稱很幸運都沒有重複到