- NAME
- EXAMPLES
- Example 1: Basic Data Gathering Using vmstat
- Example 2: Setting Minimum and Maximum Value Limits
- Example 3: Creating RRDs with Different Data Retention Periods
- Example 4: Drawing an Average Value Horizonal Rule on a Graph
- Example 5: Drawing a Fixed Height Stacked Graph
- Example 6: Setting Custom Graph Colours
- Example 7: Capacity Planning Predictions
- COPYRIGHT
NAME
RRD::Simple::Examples - Examples using RRD::Simple
EXAMPLES
Example 1: Basic Data Gathering Using vmstat
use strict; use RRD::Simple; my $cmd = "/usr/bin/vmstat 2 3"; my $rrdfile = "vmstat-cpu.rrd"; my $rrd = RRD::Simple->new( file => $rrdfile ); my @keys = (); my %update = (); open(PH,"-|",$cmd) or die qq{Unable to open file handle PH for command "$cmd": $!}; while (local $_ = <PH>) { next if /---/; s/^\s+|\s+$//g; if (/\d+/ && @keys) { @update{@keys} = split(/\s+/,$_); } else { @keys = split(/\s+/,$_); } } close(PH) or die qq{Unable to close file handle PH for command "$cmd": $!}; my @cpukeys = splice(@keys,-4,4); my %labels = (wa => "IO wait", id => "Idle", sy => "System", us => "User"); $rrd->create(map { ($_ => "GAUGE") } @cpukeys) unless -f $rrdfile; $rrd->update(map { ($_ => $update{$_}) } @cpukeys);
Example 2: Setting Minimum and Maximum Value Limits
This example shows how to set the minimum value to zero on a datasource using the RRDs::tune function. Use -i
or --minimum
to set the minimum value, and -a
or --maximum
to set the maximum value.
See http://www.rrdtool.org/rrdtool/doc/rrdtune.en.html.
use strict; use RRD::Simple; use RRDs; my %update = (); my $cmd = "/usr/bin/iostat -k"; open(PH,"-|",$cmd) or die qq{Unable to open file handle PH for command "$cmd": $!}; while (local $_ = <PH>) { if (my ($dev,$r,$w) = $_ =~ /^([\w\d]+)\s+\S+\s+\S+\s+\S+\s+(\d+)\s+(\d+)$/) { $update{$dev} = { "read" => $r, "write" => $w }; } } close(PH) or die qq{Unable to close file handle PH for command "$cmd": $!}; for my $dev (keys %update) { my $rrdfile = "iostat-$dev.rrd"; my $rrd = RRD::Simple->new( file => $rrdfile ); unless (-f $rrdfile) { $rrd->create( map { ($_ => "DERIVE") } sort keys %{$update{$dev}} ); RRDs::tune($rrdfile, "-i", "$_:0") for keys %{$update{$dev}}; } $rrd->update(%{$update{$dev}}); }
Example 3: Creating RRDs with Different Data Retention Periods
The second (optional) parameter to the create method is the data retention period. Valid values are "day", "week", "month", "year", "3years" and "mrtg". The default value is "mrtg".
The "mrtg" data retention period uses a data stepping resolution of 300 seconds (5 minutes) and heartbeat of 600 seconds (10 minutes), whereas all the other data retention periods use a data stepping resolution of 60 seconds (1 minute) and heartbeat of 120 seconds (2 minutes).
use strict; use RRD::Simple; my $rrd = RRD::Simple->new( file => "myfile.rrd" ); my @period = qw(day week month year 3years mrtg); $rrd->create($period[1], datasource1 => "GAUGE", datasource2 => "GAUGE", datasource3 => "GAUGE", );
Example 4: Drawing an Average Value Horizonal Rule on a Graph
Graph parameters are preserved and should be passed through to RRDs correctly: VDEF, CDEF, DEF, GPRINT, PRINT, COMMENT, HRULE, VRULE, LINE, AREA, TICK, SHIFT and STACK. Use the VDEF and HRULE parameters to draw a horizontal rule on your graph.
use strict; use RRD::Simple; my $rrd = RRD::Simple->new( file => "frequency.rrd" ); $rrd->create("day", Frequency => "GAUGE", ); my $end = time(); my $start = $end - (60 * 60 * 24); my $i = 0; my $rand = int(rand(100)); for (my $t = $start; $t <= $end; $t += 60) { $rrd->update($t, Frequency => ( cos($i += 0.01) * 100 ) + $rand, ); } $rrd->graph( sources => [ qw(Frequency) ], "VDEF:FrequencyAVERAGE=Frequency,AVERAGE" => "", "HRULE:FrequencyAVERAGE#00ff77:Average" => "", );
Example 5: Drawing a Fixed Height Stacked Graph
use strict; use RRD::Simple; my $rrdfile = "vmstat-cpu.rrd"; my $rrd = RRD::Simple->new( file => $rrdfile ); $rrd->graph( title => "CPU Utilisation", vertical_label => "% percent", upper_limit => 100, lower_limit => 0, rigid => "", sources => [ qw(sy us wa id) ], source_drawtypes => [ qw(AREA STACK STACK STACK) ], extended_legend => 1, );
Example 6: Setting Custom Graph Colours
The color
parameter can be used to override the default colours for standard elements of the graph. Valid elements are: BACK, CANVAS, SHADEA, SHADEB, GRID, MGRID, FONT, AXIS, FRAME and ARROW. See http://oss.oetiker.ch/rrdtool/doc/rrdgraph.en.html for further information.
use strict; use RRD::Simple; my $rrd = RRD::Simple->new( file => "vmstat-cpu.rrd" ); $rrd->graph( title => "CPU Utilisation", source_colors => { sy => "ff0000", us => "00ff00", wa => "0000ff", id => "ffffff", }, color => [ ( "BACK#F5F5FF", "SHADEA#C8C8FF", "SHADEB#9696BE", "ARROW#61B51B", "GRID#404852", "MGRID#67C6DE" ) ], );
Example 7: Capacity Planning Predictions
use strict; use RRD::Simple 1.44; my $rrd = RRD::Simple->new( file => "memory_usage.rrd" ); $rrd->graph( periods => [ qw(week month) ], title => "Memory Utilisation", base => 1024, vertical_label => "bytes", sources => [ qw(Total Used) ], source_drawtypes => [ qw(AREA LINE) ], source_colors => [ qw(dddddd 0000dd) ], lower_limit => 0, rigid => "", "VDEF:D=Used,LSLSLOPE" => "", "VDEF:H=Used,LSLINT" => "", "VDEF:F=Used,LSLCORREL" => "", "CDEF:Proj=Used,POP,D,COUNT,*,H,+" => "", "LINE2:Proj#800000: Projection" => "", );
'Programming > RRD' 카테고리의 다른 글
[RRD] RRGrapher (0) | 2014.01.29 |
---|---|
[RRD] Using rrdtool to graph vmstat output - a worked example (0) | 2014.01.29 |
[RRD] Convert sar text output into RRDTool Graphs (0) | 2014.01.29 |
[RRD] rrdgraph_examples (0) | 2014.01.29 |
[RRD] Digitemp data visualisation on your website (0) | 2014.01.29 |