rrdtool PDP 值是如何计算的?
How is rrdtool PDP value calculated?
当我创建 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 毫秒。我说得对吗?
值 包含 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.
当我创建 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 毫秒。我说得对吗?
值 包含 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.