Как рассчитывается значение PDP rrdtool? - PullRequest
0 голосов
/ 07 марта 2019

Когда я создаю базу данных RRD и обновляю ее значением GAUGE 100, тогда значение PDP value устанавливается равным 26,877900000.Когда я создаю базу данных RRD примерно через секунду, тогда PDP value равен 17,477500000:

usr@PC:~$ rm foo.rrd; rrdtool create foo.rrd --start 'N' --step '300' 'DS:RTT:GAUGE:600:0:1000000' 'RRA:AVERAGE:0.5:1:1440'; rrdtool update foo.rrd N:100; rrdtool dump foo.rrd | grep --color -E '<value>[0-9]+|<unknown_sec>|<lastupdate>'
        <lastupdate>1551973741</lastupdate> <!-- 2019-03-07 17:49:01 EET -->
                <value>2.6877900000e+01</value>
                <unknown_sec> 241 </unknown_sec>
usr@PC:~$ rm foo.rrd; rrdtool create foo.rrd --start 'N' --step '300' 'DS:RTT:GAUGE:600:0:1000000' 'RRA:AVERAGE:0.5:1:1440'; rrdtool update foo.rrd N:100; rrdtool dump foo.rrd | grep --color -E '<value>[0-9]+|<unknown_sec>|<lastupdate>'
        <lastupdate>1551973742</lastupdate> <!-- 2019-03-07 17:49:02 EET -->
                <value>1.7477500000e+01</value>
                <unknown_sec> 242 </unknown_sec>
usr@PC:~$ 

Как рассчитывается этот PDP value?Я предполагаю, что в первый раз rrdtool update foo.rrd N:100 произошло на 268,779 мс позже, чем rrdtool create.И во второй раз rrdtool update foo.rrd N:100 произошло на 174,775 мс позже, чем rrdtool create.Я прав?

1 Ответ

1 голос
/ 18 марта 2019

значение содержит rate*seconds, которое имело место до последнего запуска.

Дамп реализации здесь: rrd_dump.c

            CB_FMTS("\t\t<value>%0.10e</value>\n",
                rrd.pdp_prep[i].scratch[PDP_val].u_val);

Описание pdp_prep[].scratch[PDP_val].u_val вы можете найти здесь: rrd_update.c # L1689

    /* in pdp_prep[].scratch[PDP_val].u_val we have collected
       rate*seconds which occurred up to the last run.
...