[rrd-users] last average is NaN?
Alex van den Bogaerdt
alex at vandenbogaerdt.nl
Wed Jan 14 04:13:04 CET 2009
First a line off topic: Am I the only one having trouble to 'reply all' to
the topic starter? I know my mail+news client sucks, but this is the first
time I see the problem that a reply would be sent to my news server...
----- Original Message -----
From: "Levente Kovacs" <leventelist at gmail.com>
To: <rrd-users at lists.oetiker.ch>
Sent: Monday, January 12, 2009 1:48 AM
Subject: [rrd-users] last average is NaN?
> Hi list,
>
>
> I think rrdtool is great. I use to collect data of my thermometer project.
> Thank you for the implementation.
>
> http://logonex.eu/tc/
>
> My only question is why is that so that the last average is allways "NaN"?
>
>
> # rrdtool fetch temperature.rrd AVERAGE
>
> .
> .
> .
> 1231721100: 2.6959898817e+01 2.3159899759e+01 2.3597679153e+01
> 1231721400: nan nan nan
You get what you ask, not what rrdtool thinks you probably ment to ask. This
is a good thing, as computer programs aren't good in guessing. They would
often guess right, meaning they sometimes guess wrong. It's better if you
are in control, provided that you ask the right questions.
Try the following two almost identical examples:
(adjust these timestamps to the current timestamps you see)
rrdtool fetch temperature.rrd --end 1231721100
rrdtool fetch temperature.rrd --end 1231721101
Notice the difference? You are not, then you are, asking for data after
1231721100.
The last update was somewhere between 1231721100 and 1231721400, but what
matters here is which data is consolidated into an RRA. Not all of the data
between 1231721100 and 1231721400 is known, this is filled in as soon as you
do an update at or after 1231721400.
Later, when you understand more of rrdtool, visit my site (
http://www.vandenbogaerdt.nl/rrdtool/ ) and read about normalization,
consolidation and such.
A quick(ish) fix is:
1: rrdtool last temperature.rrd
this returns a number, such as 123172105
2: echo 1231721105/300*300|bc
this performs an integer division and multiplication, resulting in 123172100
3: rrdtool fetch --end 123172100 temperature.rrd AVERAGE
And of course you should use a variable instead of the numer 123172105 and
such.
ts=`rrdtool last temperature.rrd`
ts=`echo $ts/300*300|bc`
rrdtool fetch --end $ts temperature.rrd AVERAGE
shorter equivalent in bash:
rrdtool fetch --end $(($(rrdtool last temperature.rrd)/300*300))
temperature.rrd AVERAGE
And there will be many more possible solutions, this is not a contest.
HTH
Alex
More information about the rrd-users
mailing list