rrdtool PDP值如何计算?

时间:2019-03-07 15:58:19

标签: rrdtool

当我创建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第一次比rrdtool create发生268.779毫秒。第二次rrdtool update foo.rrd N:100发生的时间比rrdtool create晚174.775毫秒。我说得对吗?

1 个答案:

答案 0 :(得分:1)

包含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.