Erinevus lehekülje "RRDtool ja võrgugraafik" redaktsioonide vahel
(→HTML) |
(→HTML) |
||
292. rida: | 292. rida: | ||
Loome mingi [[:HTML]] lehekülje, milles kõik neli graafikut üheskoos. | Loome mingi [[:HTML]] lehekülje, milles kõik neli graafikut üheskoos. | ||
+ | |||
+ | <source lang="html4strict"> | ||
+ | |||
+ | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" | ||
+ | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | ||
+ | <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="et" lang="et"> | ||
+ | <head> | ||
+ | <title>RRDtool graph</title> | ||
+ | <meta http-equiv="Content-type" content="text/html; charset=iso-8859-1" /> | ||
+ | <style type="text/css"> | ||
+ | html, body { | ||
+ | font-family: verdana, tahoma, arial, helvetica, "trebuchet ms"; | ||
+ | font-size: 14px; | ||
+ | font-weight: normal; | ||
+ | text-decoration: none; | ||
+ | color: #000000; | ||
+ | height: 100%; | ||
+ | background: #333; | ||
+ | color: #fff; | ||
+ | } | ||
+ | #graphs div, #timestamp { text-align: center; padding: 2px; } | ||
+ | #timestamp { font-weight: bold; } | ||
+ | </style> | ||
+ | </head> | ||
+ | <body> | ||
+ | |||
+ | <div id="timestamp">Loading the date...</div> | ||
+ | |||
+ | <div id="graphs"> | ||
+ | <div id="g_day"> | ||
+ | <img src="g-p2ev.png" alt='Day' title="Day" /> | ||
+ | </div> | ||
+ | <div id="g_week"> | ||
+ | <img src="g-n2dal.png" alt='Week' title="Week" /> | ||
+ | </div> | ||
+ | <div id="g_month"> | ||
+ | <img src="g-kuu.png" alt='Month' title="Month" /> | ||
+ | </div> | ||
+ | <div id="g_year"> | ||
+ | <img src="g-aasta.png" alt='Year' title="Year" /> | ||
+ | </div> | ||
+ | </div> | ||
+ | |||
+ | <script type="text/javascript"> | ||
+ | |||
+ | function set_date() { | ||
+ | // month array for local translation | ||
+ | months = [ "Jaanuar", "Veebruar", "Märts", "Aprill", "Mai", "Juuni", "Juuli", "August", "September", "Oktoober", "November", "Detsember" ]; | ||
+ | |||
+ | d = new Date(); // get date for the string | ||
+ | |||
+ | // format hour, minute and second number | ||
+ | h = (String(d.getHours()).length == 1 ? "0"+d.getHours() : d.getHours()); | ||
+ | m = (String(d.getMinutes()).length == 1 ? "0"+d.getMinutes() : d.getMinutes()); | ||
+ | s = (String(d.getSeconds()).length == 1 ? "0"+d.getSeconds() : d.getSeconds()); | ||
+ | |||
+ | // set the date str | ||
+ | date_str= | ||
+ | ("0"+d.getDate()).substr(-2,2)+"-"+(months[d.getMonth()])+"-"+(d.getFullYear())+" "+ | ||
+ | h+":"+m+":"+s; | ||
+ | |||
+ | // pollute element with date str | ||
+ | document.getElementById("timestamp").innerHTML = date_str; | ||
+ | } | ||
+ | |||
+ | set_date(); // run date set function | ||
+ | |||
+ | </script> | ||
+ | |||
+ | </body> | ||
+ | </html> | ||
+ | </source> | ||
===Andkefailide konvert enne teisele arhidektuurile tõstmist=== | ===Andkefailide konvert enne teisele arhidektuurile tõstmist=== |
Redaktsioon: 22. aprill 2013, kell 14:13
Sisukord
Sissjuhatus
RRDtool on vabavaraline andmete hoidmise ja graafikute loomise vahend. See toetab mistahes arvulisi andmemassiive. Näiteks: võrguliiklus, temperatuur, protsessori kasutus, kõvaketta ruum, aktiivsed võrguühendused, failide arv kettal jms.
Install
Paigaldame serverisse SNMP teenuse. Täpsemalt on selle paigaldamisest juttu palas net-snmp.
Paigaldame ka rakenduse RRDtool.
Andmefaili loomine
Kõige keerulisem osa RRDtooli juures on andmebaasi loomine, mille sees andmeid hoitakse. Järgmised parameetrid tuleb enne andmebaasi loomist välja selgitada:
1. kui tihti andmeid lisatakse? [--step X] (samm on vaikimisi 300 sekundit) 2. mitut erinevat andmejada andmebaasis hoitakse? 3. kui pika aja kohta andmeid hoitakse?
Loome võrguliikluse andmebaasi, kus andmete uuendamine toimub iga 300 sekundi (5 minutit) tagant. Meil on vaja graafikut nii ööpäeva, nädala, kuu kui aasta jaoks.
Käivitamie järgmise käsu:
rrdtool create liiklus.rrd \ --step 300 \ DS:in:COUNTER:600:U:U \ DS:out:COUNTER:600:U:U \ RRA:AVERAGE:0.5:1:288 \ RRA:AVERAGE:0.5:6:336 \ RRA:AVERAGE:0.5:24:372 \ RRA:AVERAGE:0.5:288:365 \ RRA:MAX:0.5:1:288 \ RRA:MAX:0.5:6:336 \ RRA:MAX:0.5:24:372 \ RRA:MAX:0.5:288:365 \
Selle tulemusel tekib anmebaasifail nimega liiklus.rrd. Nüüd natuke lähemalt, mida me siin tegime.
DS:in:COUNTER:600:U:U ja DS:out:COUNTER:600:U:U
Sedasi tekitatakse baasi andmejada nimega 'in' ja 'out', mis on COUNTER tüüpi, andmepunkt iga 600 sekundi tagant, mille minimaalne ja maksimaale väärtus on teadmata (U). Kui on teada minimaalne või maksimaalne väärtus, võib selle loomulikult ka baasi loomisel paika panna. Selle näite puhul jätame selle aga kujule Unknown (U).
RRA:AVERAGE:0.5:1:288
288 andmeühikut! 1 (iga uuendus) * 300 sekundit (uuenduse samm) * 288 (andmepunkti) = 86400 sekundit 86400 sekundit / 60 => 1440 minutit 1440 minutit / 60 => 24 tundi 24 tundi / 24 => 1 ööpäev
RRA:AVERAGE:0.5:6:336
336 andmeühikut! 6 (uuenduste keskmine) * 300 sekundit (uuenduse samm) * 336 (andmepunkti) = 604800 sekundit 604800 sekundit / 60 => 10080 minutit 10080 minutit / 60 => 168 tundi 168 tundi / 24 => 7 ööpäeva
RRA:AVERAGE:0.5:24:372
336 andmeühikut! 24 (uuenduste keskmine) * 300 sekundit (uuenduse samm) * 372 (andmepunkti) = 2678400 sekundit 2678400 sekundit / 60 => 44640 minutit 44640 minutit / 60 => 744 tundi 744 tundi / 24 => 31 ööpäeva
RRA:AVERAGE:0.5:288:365
365 andmeühikut! 288 (uuenduste keskmine) * 300 sekundit (uuenduse samm) * 365 (andmepunkti) = 31536000 sekundit 31536000 sekundit / 60 => 525600 minutit 525600 minutit / 60 => 8760 tundi 8760 tundi / 24 => 365 ööpäeva
Sarnaselt eelnevale (AVERAGE e. keskmine) on defineeritud ka maksimaalsete väärtuste hoidmine samas ajaskaalas (MAX).
Andmete uuendamine
Andmete uuendamiseks on otstarbekas luua skript, mis küsib operatsioonisüsteemi (või mingi teenuse, nagu näiteks SNMP) käest andmeid ning salvestab need andmebaasi.
Kohandame skriptis failirajad ning võrgukaardi numbri vastavalt serveri konfiguratsioonile parajaks.
#!/bin/sh
# sisenevad bitid
sin=`/usr/local/bin/snmpget -v 1 -c <parool> -Oqv localhost IF-MIB::ifInOctets.3`
# väljjuvad bitid
sout=`/usr/local/bin/snmpget -v 1 -c <parool> -Oqv localhost IF-MIB::ifOutOctets.3`
# väljastame kontrolliks siseneva ja väljuva liikluse numbrid
echo Snmp in : $sin
echo Snmp out: $sout
# uuendame infoga liiklus.rrd faili. viitame rrdupdate käsule läbi täispika kaustapuu!
/usr/local/bin/rrdupdate /home/kasutaja/rrdtool/liiklus.rrd N:$sin:$sout
Pööra tähelepanu ridadele sin ja sout!
sin=`/usr/local/bin/snmpget -v 1 -c <parool> -Oqv localhost IF-MIB::ifInOctets.2`
sout=`/usr/local/bin/snmpget -v 1 -c <parool> -Oqv localhost IF-MIB::ifOutOctets.2`
Number üks (ifInOctets.1) tähistab antud arvuti konfiguratsioonis välisvõrgukaardi numbrit. Oma serveri parameetrite leidmiseks sisesta käsk:
snmpwalk -v 1 -c <parool> localhost | grep ifDescr
Antud serveri konfiguratsioonile vastavalt oli tulemus järgmine, kus ifDescr.1 on väline (fxp0) ja ifDescr.2 sisemine (fxp1) võrgukaart:
IF-MIB::ifDescr.1 = STRING: fxp0 IF-MIB::ifDescr.2 = STRING: fxp1
Kõikide võimalike nimetuste ja väärtuste kuvamiseks:
snmpwalk -v 1 -c <parool> localhost | more
Graafikute loomine
Paigaldame skripti g.sh, mis loob rrd andmebaasi andmete järgi graafikud. Konfiguratsiooni osas määra sobivad väärtused.
#!/bin/sh
# Konfiguratsioon
rrdtool="/usr/local/bin/rrdtool" # rrdtool'i asukoht kettal (crontab n6uab t2ispikka kaustapud)
image_path="/root/rrdtool/graphs" # kaust, kuhu graafikud salvestatakse
location="Kurelaane" # location @ date => graafiku alumises servas olev sõne
database="/root/rrdtool/liiklus.rrd" # rrd faili asukoht kettal
vertical_label='Traffic kB/s' # vertikaalne pealkiri
# Päev
$rrdtool graph $image_path/g-p2ev.png -a PNG -s -24h \
-w 800 -h 350 \
-A \
--x-grid HOUR:1:HOUR:4:MINUTE:120:0:%R \
--vertical-label "$vertical_label" \
--font DEFAULT:7: \
--color BACK#ffffff \
--border 1 \
--color SHADEA#f1f1f1 --color SHADEB#f1f1f1 \
--watermark "$location @ `date`" \
--slope-mode \
"DEF:in_def=$database:in:AVERAGE" \
"DEF:out_def=$database:out:AVERAGE" \
'CDEF:in=in_def,UN,0,in_def,IF' \
'CDEF:out=out_def,UN,0,out_def,IF' \
'CDEF:kbin=in,1024,/' \
'CDEF:kbout=out,1024,/' \
'CDEF:outg=out,-1,/' \
'CDEF:background=in,POP,LTIME,7200,%,3600,LE,INF,UNKN,IF' \
'CDEF:backgroundN=background,-1,*' \
'AREA:background#F3F3F3' \
'AREA:backgroundN#F3F3F3' \
'HRULE:600000#999999' \
'HRULE:-262144#FF0000' \
'AREA:in#83afe5' \
'AREA:outg#e6ce97' \
'LINE1:in#225ea8' \
'LINE1:outg#bf812d' \
'GPRINT:kbin:LAST:CURRENT download\: %3.2lf kB/s' \
'GPRINT:kbout:LAST:CURRENT upload\: %3.2lf kB/s\j' \
'GPRINT:kbin:AVERAGE:AVERAGE download\: %3.2lf kB/s' \
'GPRINT:kbout:AVERAGE:AVERAGE upload\: %3.2lf kB/s\j'
# Nädal
$rrdtool graph $image_path/g-n2dal.png -a PNG -s -168h \
-w 800 -h 350 \
-A \
--vertical-label "$vertical_label" \
--font DEFAULT:7: \
--color BACK#ffffff \
--border 1 \
--color SHADEA#f1f1f1 --color SHADEB#f1f1f1 \
--watermark "$location @ `date`" \
--slope-mode \
"DEF:in_def=$database:in:AVERAGE" \
"DEF:out_def=$database:out:AVERAGE" \
'CDEF:in=in_def,UN,0,in_def,IF' \
'CDEF:out=out_def,UN,0,out_def,IF' \
'CDEF:kbin=in,1024,/' \
'CDEF:kbout=out,1024,/' \
'CDEF:outg=out,-1,/' \
'CDEF:background=in,POP,LTIME,172800,%,86400,LE,INF,UNKN,IF' \
'CDEF:backgroundN=background,-1,*' \
'AREA:background#F3F3F3' \
'AREA:backgroundN#F3F3F3' \
'HRULE:600000#999999' \
'HRULE:-262144#FF0000' \
'AREA:in#83afe5' \
'AREA:outg#e6ce97' \
'LINE1:in#225ea8' \
'LINE1:outg#bf812d' \
'GPRINT:kbin:LAST:CURRENT download\: %3.2lf kB/s' \
'GPRINT:kbout:LAST:CURRENT upload\: %3.2lf kB/s\j' \
'GPRINT:kbin:AVERAGE:AVERAGE download\: %3.2lf kB/s' \
'GPRINT:kbout:AVERAGE:AVERAGE upload\: %3.2lf kB/s\j'
# Kuu
$rrdtool graph $image_path/g-kuu.png -a PNG -s -744h \
-w 800 -h 350 \
-A \
--vertical-label "$vertical_label" \
--font DEFAULT:7: \
--color BACK#ffffff \
--border 1 \
--color SHADEA#f1f1f1 --color SHADEB#f1f1f1 \
--watermark "$location @ `date`" \
--slope-mode \
"DEF:in_def=$database:in:AVERAGE" \
"DEF:out_def=$database:out:AVERAGE" \
'CDEF:in=in_def,UN,0,in_def,IF' \
'CDEF:out=out_def,UN,0,out_def,IF' \
'CDEF:kbin=in,1024,/' \
'CDEF:kbout=out,1024,/' \
'CDEF:outg=out,-1,/' \
'CDEF:background=in,POP,LTIME,1209600,%,604800,LE,INF,UNKN,IF' \
'CDEF:backgroundN=background,-1,*' \
'AREA:background#F3F3F3' \
'AREA:backgroundN#F3F3F3' \
'HRULE:600000#999999' \
'HRULE:-262144#FF0000' \
'AREA:in#83afe5' \
'AREA:outg#e6ce97' \
'LINE1:in#225ea8' \
'LINE1:outg#bf812d' \
'GPRINT:kbin:LAST:CURRENT download\: %3.2lf kB/s' \
'GPRINT:kbout:LAST:CURRENT upload\: %3.2lf kB/s\j' \
'GPRINT:kbin:AVERAGE:AVERAGE download\: %3.2lf kB/s' \
'GPRINT:kbout:AVERAGE:AVERAGE upload\: %3.2lf kB/s\j'
# Aasta
$rrdtool graph $image_path/g-aasta.png -a PNG -s -8760h \
-w 800 -h 350 \
-A \
--vertical-label "$vertical_label" \
--font DEFAULT:7: \
--color BACK#ffffff \
--border 1 \
--color SHADEA#f1f1f1 --color SHADEB#f1f1f1 \
--watermark "$location @ `date`" \
--slope-mode \
"DEF:in_def=$database:in:AVERAGE" \
"DEF:out_def=$database:out:AVERAGE" \
'CDEF:in=in_def,UN,0,in_def,IF' \
'CDEF:out=out_def,UN,0,out_def,IF' \
'CDEF:kbin=in,1024,/' \
'CDEF:kbout=out,1024,/' \
'CDEF:outg=out,-1,/' \
'HRULE:600000#999999' \
'HRULE:-262144#FF0000' \
'AREA:in#83afe5' \
'AREA:outg#e6ce97' \
'LINE1:in#225ea8' \
'LINE1:outg#bf812d' \
'GPRINT:kbin:LAST:CURRENT download\: %3.2lf kB/s' \
'GPRINT:kbout:LAST:CURRENT upload\: %3.2lf kB/s\j' \
'GPRINT:kbin:AVERAGE:AVERAGE download\: %3.2lf kB/s' \
'GPRINT:kbout:AVERAGE:AVERAGE upload\: %3.2lf kB/s\j'
CRON
Andmete kogumise ja graafikute joonistamise automatiseerimiseks lisame need tööd Crontab tabelisse.
Lisame cron’i skriptide käivitamise, avame /etc/crontab, lisame read
*/5 * * * * root /usr/home/kasutaja/get_traffic.sh > /dev/null
*/5 * * * * root /usr/home/kasutaja/build_graph.sh > /dev/null
Nii andmete küsimine kui graafikute joonistamine leiab aset iga viie minuti tagant.
Graafik
Tulemuseks saame neli graafikut. Siinkohal toome esile ainult päevase graafiku:
HTML
Loome mingi HTML lehekülje, milles kõik neli graafikut üheskoos.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="et" lang="et">
<head>
<title>RRDtool graph</title>
<meta http-equiv="Content-type" content="text/html; charset=iso-8859-1" />
<style type="text/css">
html, body {
font-family: verdana, tahoma, arial, helvetica, "trebuchet ms";
font-size: 14px;
font-weight: normal;
text-decoration: none;
color: #000000;
height: 100%;
background: #333;
color: #fff;
}
#graphs div, #timestamp { text-align: center; padding: 2px; }
#timestamp { font-weight: bold; }
</style>
</head>
<body>
<div id="timestamp">Loading the date...</div>
<div id="graphs">
<div id="g_day">
<img src="g-p2ev.png" alt='Day' title="Day" />
</div>
<div id="g_week">
<img src="g-n2dal.png" alt='Week' title="Week" />
</div>
<div id="g_month">
<img src="g-kuu.png" alt='Month' title="Month" />
</div>
<div id="g_year">
<img src="g-aasta.png" alt='Year' title="Year" />
</div>
</div>
<script type="text/javascript">
function set_date() {
// month array for local translation
months = [ "Jaanuar", "Veebruar", "Märts", "Aprill", "Mai", "Juuni", "Juuli", "August", "September", "Oktoober", "November", "Detsember" ];
d = new Date(); // get date for the string
// format hour, minute and second number
h = (String(d.getHours()).length == 1 ? "0"+d.getHours() : d.getHours());
m = (String(d.getMinutes()).length == 1 ? "0"+d.getMinutes() : d.getMinutes());
s = (String(d.getSeconds()).length == 1 ? "0"+d.getSeconds() : d.getSeconds());
// set the date str
date_str=
("0"+d.getDate()).substr(-2,2)+"-"+(months[d.getMonth()])+"-"+(d.getFullYear())+" "+
h+":"+m+":"+s;
// pollute element with date str
document.getElementById("timestamp").innerHTML = date_str;
}
set_date(); // run date set function
</script>
</body>
</html>
Andkefailide konvert enne teisele arhidektuurile tõstmist
rrdtool puhul pole võimalik kasutada samu rrd faile nii 32 kui 64bitistel masinatel ja vahepeal tuleb need ümber konvertida ja taastada. Arendajate poolt arutatakse ka uue formaadi loomist mille puhul sarnaseid konvertimisi enam ei peaks tegema kuid hetkel seda ametlikus releasis veel pole.
Esimeses masinas konverdime kõik failid xml formaati järgneva skriptiga
#!/bin/sh for g in $( ls /usr/local/var/rrdfailid ) ; do name=`echo $g | awk '{sub(/rrd/,"xml");print}'` echo $g echo $name rrdtool dump /usr/local/var/rrdfailid/$g /usr/local/var/rrdfailid/$name done
Kopeerime failid üle teise arvutisse kus Kustutame esimesena eksisteerivad rrdfailid ja seejäärel loome neist uued rrdfailid.
#!/bin/sh for g in $( ls /usr/local/var/rrdfailid ) ; do name=`echo $g | awk '{sub(/xml/,"rrd");print}'` echo $g echo $name rrdtool restore /usr/local/var/rrdfailid/$g /usr/local/var/munin/rrdfailid/$name done
Ja seejärel võime eemaldada kopeeritud failid
Lingid
http://oss.oetiker.ch/rrdtool/
http://en.wikipedia.org/wiki/RRDtool