Hello, all. I'm trying to gather statistics from mysql with php script running on cacti box. Script returns values in correct form and cacti understand it properly and push it into rrd file. But graphs are totally wrong and I can't understand why.
Data source type is COUNTER i.e. it is always increasing. I'm acquiring data with cacti every minute. So imo in rrd file I should have last received value as "last_ds" field and the difference between this and the previous one in "value". But what I see on graph it is not corresponding to what it should be at all. The same for RRD file.
I've snapshoted several points with 1 minute period to see what do I have in RRD:
Fri Jul 16 00:45:42 PDT 2010
filename = "box_select_1672.rrd"
ds[select].type = "COUNTER"
ds[select].minimal_heartbeat = 120
ds[select].min = 0.0000000000e+00
ds[select].max = NaN
ds[select].last_ds = "323477685"
ds[select].value = 2.2713333333e+02
ds[select].unknown_sec = 0
Fri Jul 16 00:46:42 PDT 2010
filename = "box_select_1672.rrd"
ds[select].last_ds = "323480510"
ds[select].value = 1.8833333333e+02
I supposed the difference should be 323480510-323477685=2825 but not 2.2713333333e+02 ~ 227
Fri Jul 16 00:47:42 PDT 2010
filename = "box_select_1672.rrd"
ds[select].last_ds = "323482756"
ds[select].value = 1.4973333333e+02
The same here: 323482756-323480510=2246 but not 149
Fri Jul 16 00:48:42 PDT 2010
filename = "box_select_1672.rrd"
ds[select].last_ds = "323486653"
ds[select].value = 1.9815254237e+02
Fri Jul 16 00:49:43 PDT 2010
filename = "box_select_1672.rrd"
ds[select].last_ds = "323489436"
ds[select].value = 1.8249180328e+02
Does anybody have thoughts what I am doing wrong?
I'll appreciate any idea because I'm almost out of ammo.
Thanks in advance.
UPD: For those who don't want to read all of available info about RRD or just have no sufficient time I'll answer on my own question by this excerpt:
Quote:
COUNTER The input is an ever increasing number, e.g. an octet counter in a router. RRDtool should compute the difference between the last update and the current one, and divide it by the amount of time lapsed.
[SOLVED] Value in rrd file do not correspond to expected one
Moderators: Developers, Moderators
[SOLVED] Value in rrd file do not correspond to expected one
Last edited by Dolphin on Fri Jul 16, 2010 3:39 pm, edited 2 times in total.
http://www.vandenbogaerdt.nl/rrdtool/ is a great page for understanding how rrdtool works in depth.
| Scripts: Monitor processes | RFC1213 MIB | DOCSIS Stats | Dell PowerEdge | Speedfan | APC UPS | DOCSIS CMTS | 3ware | Motorola Canopy |
| Guides: Windows Install | [HOWTO] Debug Windows NTFS permission problems |
| Tools: Windows All-in-one Installer |
Thank you. Not what it is what I was expecting to get here, but maybe it's even better =)BSOD2600 wrote:http://www.vandenbogaerdt.nl/rrdtool/ is a great page for understanding how rrdtool works in depth.
For those who don't want to read all of available info about RRD or just have no sufficient time I'll answer on my own question by this excerpt:
So now I have another question, which I have no answer on. How to make it store data dividing it by 1, but not 60 seconds. Looks like I will have to find this answer by myself once more =) Anyway thanks again, BSOD2600COUNTER The input is an ever increasing number, e.g. an octet counter in a router. RRDtool should compute the difference between the last update and the current one, and divide it by the amount of time lapsed.
- gandalf
- Developer
- Posts: 22383
- Joined: Thu Dec 02, 2004 2:46 am
- Location: Muenster, Germany
- Contact:
In case you want to store computed data, you will have to use the COMPUTE data source. It accepts CDEFs to compute. COMPUTE will be supported with Cacti 088.
In many cases, it is sufficient to peform the calculation at graphing time. The same CDEF may be applied to any data source item to achieve this. This feature is available since ages with Cacti.
R.
In many cases, it is sufficient to peform the calculation at graphing time. The same CDEF may be applied to any data source item to achieve this. This feature is available since ages with Cacti.
R.
Yes, I know about CDEFs, but wanted to store data without dividing it just to decrease inaccuracy, which appears when we dividing integer values by 60 and put this data into db and then multiplying real values by 60 to graph. Now I've come to conclusion that I can live with such insignificant deviation and multiply on graphing stage.gandalf wrote:In many cases, it is sufficient to peform the calculation at graphing time. The same CDEF may be applied to any data source item to achieve this. This feature is available since ages with Cacti.
R.
Thanks all for your answers.
Who is online
Users browsing this forum: No registered users and 4 guests