Lien:
# aptitude install rrdtool
Quelque part…
$ rrdtool create test.rrd --start 920804400 DS:speed:COUNTER:600:U:U RRA:AVERAGE:0.5:1:24 RRA:AVERAGE:0.5:6:10
test.rrd | We created the round robin database called test (test.rrd) |
–start 920804400 | 7th of March, 1999 (this date translates to 920'804'400) ⇒ time(NULL) ! |
DS:speed:COUNTER:600:U:U | Our database holds one data source (DS) named “speed” that represents a counter. This counter is read every five minutes (this is the default therefore you don't have to put –step=300) |
RRA:AVERAGE:0.5:1:24 | In the same database two round robin archives (RRAs) are kept, one averages the data every time it is read (e.g., there's nothing to average) and keeps 24 samples (24 times 5 minutes is 2 hours) |
RRA:AVERAGE:0.5:6:10 | The other averages 6 values (half hour) and contains 10 such averages (e.g. 5 hours) |
$ ls -lart -rw-r--r-- 1 thierry thierry 1008 aoû 16 14:51 test.rrd
La data “–start” est facultative ! A defaut, c'est la date actuelle.
Syntaxe: DS:Nom:Type:Heartbeat:Min:Max
DS | Data Source |
Nom | libre choix |
Type | COUNTER ou GAUGE ou DERIVE ou ABSOLUTE |
Heartbeat | intervalle de temps au bout duquel une donnée est considérée comme “unknown” |
Min | valeur minimum. En dessous, la valeur est stockée “unknown”. U ⇒ pas de minimum |
Max | valeur maximum. (garde-fou) U ⇒ pas de maximum |
COUNTER
c'est pour des valeurs qui s'incremente dans le temps, comme par exemple:
GAUGE
c'est pour des valeurs occilantes dans le temps, comme par exemple:
Les autres “type” sont plus rares.
Pour chaque DS, on créé un certain nombre d'archives RRA
.
Syntaxe: RRA:CF:XFF:STEPS:ROWS
CF | facteur de consolidation entre plusieurs mesures: AVERAGE, MAX, MIN, LAST (la moyenne, le max, le min ou la dernière mesure) |
XFF | pourcentage de points acceptables. sinon unknown. “0.5” est souvent l'usage |
STEPS | ou “pdp_per_rows” (pourcentage de point par rangée). combien de mesure pour faire une donnée |
ROWS | Nombre de valeurs a garder |
Il parait qu'on rentre des “Kilometres”, mais en fait, “rrd” s'en moque un peu…
Remplissons la base de donnée comme suit:
$ rrdtool update test.rrd 920804700:12345 920805000:12357 920805300:12363 $ rrdtool update test.rrd 920805600:12363 920805900:12363 920806200:12373 $ rrdtool update test.rrd 920806500:12383 920806800:12393 920807100:12399 $ rrdtool update test.rrd 920807400:12405 920807700:12411 920808000:12415 $ rrdtool update test.rrd 920808300:12420 920808600:12422 920808900:12423
Retrouvons les données:
$ rrdtool fetch test.rrd AVERAGE --start 920804400 --end 920809200 speed 920804700: nan 920805000: 4.0000000000e-02 920805300: 2.0000000000e-02 920805600: 0.0000000000e+00 920805900: 0.0000000000e+00 920806200: 3.3333333333e-02 920806500: 3.3333333333e-02 920806800: 3.3333333333e-02 920807100: 2.0000000000e-02 920807400: 2.0000000000e-02 920807700: 2.0000000000e-02 920808000: 1.3333333333e-02 920808300: 1.6666666667e-02 920808600: 6.6666666667e-03 920808900: 3.3333333333e-03 920809200: nan 920809500: nan
Cela est correct:
12357-12345 = 12 12:10 - 12:05 = 5
Attention:
Donc: 5*60 = 300 secondes
Soit:
(12357-12345) / ( 5*60 ) => 12/300 => 0.040
C'est bien ça:
920805000: 4.0000000000e-02
Creation de graphique:
$ rrdtool graph speed.png --start 920804400 --end 920808000 DEF:myspeed=test.rrd:speed:AVERAGE LINE2:myspeed#FF0000
Expliquons vite:
–start / –end | periode de temps a considerer |
DEF:myspeed=test.rrd:speed:AVERAGE | definition d'une “variable” “myspeed” en utilisant le “RRA” speed |
LINE2:myspeed#FF0000 | Tracé avec une epaisseur de “2” (points?) , et en rouge |
On peut donc changé la couleur… huhuhu
![]() | 40 m signifie “40 milli” |
0.040 => 40/1000 => 40 m
$ rrdtool graph speed.png --start 920804400 --end 920808000 --vertical-label m/s DEF:myspeed=test.rrd:speed:AVERAGE CDEF:realspeed=myspeed,1000,\* LINE2:realspeed#FF0000
On a ajouté un “label” vertical, et appliqué un petit calcul dans une nouvelle variable, afin de la tracer.
En ajoutant un label, et multipliant par “1000”, on ne modifie que la présentation, notamment et faisant disparaitre le “m”.
“CDEF” semble signifier une definition par un calcul.
CDEF:realspeed=myspeed,1000,\* | The calculations are specified in the CDEF part above and are in Reverse Polish Notation (“RPN”). What we requested RRDtool to do is: “take the data source myspeed and the number 1000; multiply those” |
Cela aurait été different si on avait entré comme données des “metres” au lieu de “kilomètres”… mais c'est pour illuster.
$ rrdtool graph speed.png --start 920804400 --end 920808000 --vertical-label km/s DEF:myspeed=test.rrd:speed:AVERAGE "CDEF:kmh=myspeed,3600,*" CDEF:fast=kmh,100,GT,kmh,0,IF CDEF:good=kmh,100,GT,0,kmh,IF HRULE:100#0000FF:"Maximum allowed" AREA:good#00FF00:"Good speed" AREA:fast#FF0000:"Too fast"
Explications:
C'est du polonais
(((kmh,100)GT),kmh,0)IF
GT ⇒ Greater than
Donc:
(((kmh,100)GT),kmh,0)IF
Si “kmh” est plus grand que “100”, alors retourner “kmh” Sinon, si “kmh” est plus petit ou egale a “100”, alors retourner “0”
C'est l'inverse de la précédente.
Si “kmh” est plus grand que “100”, alors retourner “0”, sinon “kmh” .
C'est simple le polonais
$ rrdtool graph speed4.png \ --start 920804400 --end 920808000 \ --vertical-label km/h \ DEF:myspeed=test.rrd:speed:AVERAGE \ "CDEF:kmh=myspeed,3600,*" \ CDEF:fast=kmh,100,GT,100,0,IF \ CDEF:over=kmh,100,GT,kmh,100,-,0,IF \ CDEF:good=kmh,100,GT,0,kmh,IF \ HRULE:100#0000FF:"Maximum allowed" \ AREA:good#00FF00:"Good speed" \ AREA:fast#550000:"Too fast" \ STACK:over#FF0000:"Over speed"
Je voudrais stocker des températures sur +2 ans…
On va prendre un “heartbeat” de 5 minutes… donc, on garantie d'avoir une nouvelle valeur au moins toutes les 5 minutes !
5 * 60 => 300 secondes
Ce qui donne comme paramètre:
DS:temp:GAUGE:300:-80:+80
Je pose des limites minimum/maximum. (Parce que le capteur n'est pas a l'abri d'un bug!)
On veut garder les valeurs sur 2 jours au moins… Donc:
2 jours => 172800 secondes
En “heartbeat” ca donne:
172800 / 300 => 576
Soyons un peu plus généreux, et on arrondi a:
600 ( => (600*300)/(24*60*60) ) => 2 jours et 2 heures )
Ce qui nous donne un premier paramètre “RRA” comme cela:
RRA:AVERAGE:0.5:1:600
600 valeurs
.En conséquence: 600 * 300 ⇒ 2 jours et 2 heures.
On veut garder les valeurs sur 14 jours au moins, mais avec un peu moins de precisions.
Donc:
14 jours => 1209600 secondes
En “heartbeat” ca devient:
1209600 / 300 => 4032
Mais c'est beaucoup trop de valeurs a stocker… On va essayer de s'approcher des “600” valeurs stockable.
1209600 / 600 => 2016 secondes
Donc, 1 information devrait être la moyenne (average) d'une periode de “2016 secondes”.
Convertit en “heartbeat”, cela devient:
2016 / 300 => 6.72
On arrondit a 6
Finalement, on a besoin de 6
informations pour constituer une valeur stockable.
6 * 300 => 30 minutes
On fera donc la moyenne sur 6 informations, c'est a dire une période de temps de 30 minutes.
C'est acceptable pour garder 14 jours de valeurs…. Enfin, un peu plus maintenant:
Pour 14 jours, on a besoin de :
1209600 / ( 6 * 300 ) => 672 valeurs
On va encore arrondir a 700
, soit:
300 * 6 * 700 => 1260000 => 14.5 jours
Bien. Cela devient comme parametre:
RRA:AVERAGE:0.5:6:700
C'est bien, mais on veut garder au moins 2 mois, soit 8 semaines.
Donc:
8 semaines => 60 jours
Ce qui donne:
5184000 secondes
Convertissons de suite en “600 valeurs”:
5184000 / 600 => 8640 secondes
Donc, chaque valeur stocké couvrira une période de 8640 secondes
soit 2 heure et 24 minutes
.
Ca serait plus fun d'arrondir la période à 2 heures
On y va:
2 * 60 => 7200 secondes
Finalement, on a besoin que de “720” valeurs pour couvrir la période… effectivement:
3974400 / 7200 => 720
En “heartbeat” cela devient:
7200 / 300 => 24
On a donc besoin de 24
echantillons.
300 * 24 * 720 ⇒ 5184000 secondes ⇒ 60 jours
Pile ! Allez, j'ajoute 2 jours: 744 valeurs
Bien. Cela devient comme parametre:
RRA:AVERAGE:0.5:24:744
Pour 6 mois ⇒ soit environ 183 jours
183 jours => 15811200 secondes
On va jouer avec des périodes de 6 heures.
Donc:
6 heures => 21600 secondes
En “heartbeat” cela devient:
21600 / 300 => 72
Pour couvrir 183 jours, il faudra donc:
15811200 / ( 300 * 72 ) => 732
Bien. Cela devient comme parametre:
RRA:AVERAGE:0.5:72:732
Là, on va taper dans 1 valeur par jour ! parce 24 mois, ca fait 730 jours (environ).
Donc, c'est trés simple:
En “heartbeat” ca donne:
24 heures => 86400 secondes 86400 / 300 => 288
RRA:AVERAGE:0.5:288:730
C'est émouvant.
$ rrdtool create poubelle.rrd DS:temp:GAUGE:300:-80:+80 RRA:AVERAGE:0.5:1:600 RRA:AVERAGE:0.5:6:700 RRA:AVERAGE:0.5:24:744 RRA:AVERAGE:0.5:72:732 RRA:AVERAGE:0.5:288:730
$ ls -la -rw-r--r-- 1 thierry thierry 29360 2008-08-17 23:59 poubelle.rrd