Blame src/components/appio/tests/iozone/report.pl

Packit 577717
#!/usr/bin/perl
Packit 577717
#
Packit 577717
# arguments: one of more report files
Packit 577717
#
Packit 577717
# Christian Mautner <christian * mautner . ca>, 2005-10-31
Packit 577717
#
Packit 577717
# This script is based loosely on the Generate_Graph set
Packit 577717
# of scripts that come with iozone, but is a complete re-write
Packit 577717
#
Packit 577717
# The main reason to write this was the need to compare the behaviour of
Packit 577717
# two or more different setups, for tuning filesystems or
Packit 577717
# comparing different pieces of hardware.
Packit 577717
#
Packit 577717
# This script is in the public domain, too short and too trivial
Packit 577717
# to deserve a copyright.
Packit 577717
#
Packit 577717
# Simply run iozone like, for example, ./iozone -a -g 4G > config1.out (if your machine has 4GB)
Packit 577717
# and then run perl report.pl config1.out
Packit 577717
# or get another report from another box into config2.out and run
Packit 577717
# perl report.pl config1.out config2.out
Packit 577717
# the look in the report_* directory for .png
Packit 577717
#
Packit 577717
# If you don't like png or the graphic size, search for "set terminal" in this file and put whatever gnuplot
Packit 577717
# terminal you want. Note I've also noticed that gnuplot switched the set terminal png syntax
Packit 577717
# a while back, you might need "set terminal png small size 900,700"
Packit 577717
#
Packit 577717
Packit 577717
Packit 577717
@Reports=@ARGV;
Packit 577717
Packit 577717
die "usage: $0 <iozone.out> [<iozone2.out>...]\n" if not @Reports or grep (m|^-|, @Reports);
Packit 577717
Packit 577717
die "report files must be in current directory" if grep (m|/|, @Reports);
Packit 577717
Packit 577717
%columns=(
Packit 577717
         'write'     =>3,
Packit 577717
         'read'      =>5,
Packit 577717
         'rewrite'   =>4,
Packit 577717
         'reread'    =>6,
Packit 577717
         'randread'  =>7,
Packit 577717
         'randwrite' =>8,
Packit 577717
         'bkwdread'  =>9,
Packit 577717
         'recrewrite'=>10,
Packit 577717
         'strideread'=>11,
Packit 577717
         'fwrite'    =>12,
Packit 577717
         'frewrite'  =>13,
Packit 577717
         'fread'     =>14,
Packit 577717
         'freread'   =>15,
Packit 577717
         );
Packit 577717
Packit 577717
#
Packit 577717
# create output directory. the name is the concatenation
Packit 577717
# of all report file names (minus the file extension, plus
Packit 577717
# prefix report_)
Packit 577717
#
Packit 577717
$outdir="report_".join("_",map{/([^\.]+)(\..*)?/ && $1}(@Reports));
Packit 577717
Packit 577717
print STDERR "Output directory: $outdir ";
Packit 577717
Packit 577717
if ( -d $outdir )
Packit 577717
{
Packit 577717
    print STDERR "(removing old directory) ";
Packit 577717
    system "rm -rf $outdir";
Packit 577717
}
Packit 577717
Packit 577717
mkdir $outdir or die "cannot make directory $outdir";
Packit 577717
Packit 577717
print STDERR "done.\nPreparing data files...";
Packit 577717
Packit 577717
foreach $report (@Reports)
Packit 577717
{
Packit 577717
    open(I, $report) or die "cannot open $report for reading";
Packit 577717
    $report=~/^([^\.]+)/;
Packit 577717
    $datafile="$1.dat";
Packit 577717
    push @datafiles, $datafile;
Packit 577717
    open(O, ">$outdir/$datafile") or die "cannot open $outdir/$datafile for writing";
Packit 577717
    open(O2, ">$outdir/2d-$datafile") or die "cannot open $outdir/$datafile for writing";
Packit 577717
    while()
Packit 577717
    {
Packit 577717
        next unless ( /^[\s\d]+$/ );
Packit 577717
        @split = split();
Packit 577717
        next unless ( @split >= 8 );
Packit 577717
        print O;
Packit 577717
        print O2 if $split[1] == 16384 or $split[0] == $split[1];
Packit 577717
    }
Packit 577717
    close I, O, O2;
Packit 577717
}
Packit 577717
Packit 577717
print STDERR "done.\nGenerating graphs:";
Packit 577717
Packit 577717
foreach $column (keys %columns)
Packit 577717
{
Packit 577717
    print STDERR " $column";
Packit 577717
Packit 577717
    open(G, ">$outdir/$column.do") or die "cannot open $outdir/$column.do for writing";
Packit 577717
    print G qq{
Packit 577717
set title "Iozone performance: $column"
Packit 577717
set grid lt 2 lw 1
Packit 577717
set surface
Packit 577717
set parametric
Packit 577717
set xtics
Packit 577717
set ytics
Packit 577717
set logscale x 2
Packit 577717
set logscale y 2
Packit 577717
set autoscale z
Packit 577717
#set xrange [2.**5:2.**24]
Packit 577717
set xlabel "File size in KBytes"
Packit 577717
set ylabel "Record size in Kbytes"
Packit 577717
set zlabel "Kbytes/sec"
Packit 577717
set style data lines
Packit 577717
set dgrid3d 80,80,3
Packit 577717
#set terminal png small picsize 900 700
Packit 577717
set terminal png small size 900 700
Packit 577717
set output "$column.png"
Packit 577717
};
Packit 577717
Packit 577717
    print G "splot ". join(", ", map{qq{"$_" using 1:2:$columns{$column} title "$_"}}(@datafiles));
Packit 577717
Packit 577717
    print G "\n";
Packit 577717
Packit 577717
    close G;
Packit 577717
Packit 577717
    open(G, ">$outdir/2d-$column.do") or die "cannot open $outdir/$column.do for writing";
Packit 577717
    print G qq{
Packit 577717
set title "Iozone performance: $column"
Packit 577717
#set terminal png small picsize 450 350
Packit 577717
set terminal png small size 450 350
Packit 577717
set logscale x
Packit 577717
set xlabel "File size in KBytes"
Packit 577717
set ylabel "Kbytes/sec"
Packit 577717
set output "2d-$column.png"
Packit 577717
};
Packit 577717
Packit 577717
    print G "plot ". join(", ", map{qq{"2d-$_" using 1:$columns{$column} title "$_" with lines}}(@datafiles));
Packit 577717
Packit 577717
    print G "\n";
Packit 577717
Packit 577717
    close G;
Packit 577717
Packit 577717
    if ( system("cd $outdir && gnuplot $column.do && gnuplot 2d-$column.do") )
Packit 577717
    {
Packit 577717
        print STDERR "(failed) ";
Packit 577717
    }
Packit 577717
    else
Packit 577717
    {
Packit 577717
        print STDERR "(ok) ";
Packit 577717
    }
Packit 577717
}
Packit 577717
Packit 577717
print STDERR "done.\n";