如何创建具有特定时间的 rrd 文件?

How to create a rrd file with a specific time?

我创建了一个带有特定时间的 rrd 文件。但是当我将其转换为xml时,我发现开始时间与指定时间不一致。

rrdtool的版本是1.5.5。

密码是

> rrdtool create abc.rrd \ 
> step 15 --start 1554122342 \  DS:sum:GAUGE:120:U:U \  RRA:AVERAGE:0.5:1:5856 \  RRA:AVERAGE:0.5:4:20160 \ 
> RRA:AVERAGE:0.5:40:52704

前几行像

> <!-- 2019-03-31 20:15:15 CST / 1554034515 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:15:30 CST / 1554034530 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:15:45 CST / 1554034545 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:16:00 CST / 1554034560 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:16:15 CST / 1554034575 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:16:30 CST / 1554034590 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:16:45 CST / 1554034605 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:17:00 CST / 1554034620 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:17:15 CST / 1554034635 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:17:30 CST / 1554034650 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:17:45 CST / 1554034665 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:18:00 CST / 1554034680 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:18:15 CST / 1554034695 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:18:30 CST / 1554034710 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:18:45 CST / 1554034725 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:19:00 CST / 1554034740 --> <row><v>NaN</v></row>
>           <!-- 2019-03-31 20:19:15 CST / 1554034755 --> <row><v>NaN</v></row>

我尝试了其他参数,比如默认(now-10s),但是间隔大约是一天。

(我下面的示例使用 RRDTool 1.5.5 进行了测试)

您的 RRA 大约持续 1 年,间隔 10 分钟;用 15 秒设置 RRD。

创建RRD时,start时间为最近数据点或最后更新的时间;换句话说,您不能添加任何早于此时间的数据。 RRA 将始终用 unknown 初始化。

因此,当您创建 RRD 时:

rrdtool create abc.rrd --step 15 --start 1554122342  \
    DS:sum:GAUGE:120:U:U RRA:AVERAGE:0.5:40:52704`

您可以使用 rrdtool info(为清楚起见对输出进行了修剪):

$ rrdtool info abc.rrd 
filename = "abc.rrd"
...
last_update = 1554122342

当您随后使用 rrdtool dump 立即查看 RRA 的内容时,您可以看到它大约提前一年开始:

$ rrdtool dump abc.rrd
...
<lastupdate>1554122342</lastupdate> <!-- 2019-04-02 01:39:02 NZDT -->
...
    <database>
        <!-- 2018-04-01 01:40:00 NZDT / 1522500000 --> <row><v>NaN</v></row>
        <!-- 2018-04-01 01:50:00 NZDT / 1522500600 --> <row><v>NaN</v></row>
...
        <!-- 2019-04-02 01:20:00 NZDT / 1554121200 --> <row><v>NaN</v></row>
        <!-- 2019-04-02 01:30:00 NZDT / 1554121800 --> <row><v>NaN</v></row>
    </database>

但是等一下!这结束于 1554121800,但我们的最后更新(开始时间)是 1554122342!这是542的差异。为什么会这样?

原因是虽然你的step是15s,但是RRA间隔是40steps,IE 600s。直到有600s的数据才能添加下一个条目,而我们只有542个。因此,RRA中的最后一个条目如图所示。请注意,所有间隔都相对于 UCT 进行了标准化,因此您的 RRA cdp(合并数据点)将始终是间隔大小的倍数 - 在本例中为 600 - 无论您何时将 'start' 设置为。 RRDTool 将简单地选择最接近的。当您滚动到很长一段时间时,这种行为会变得更加明显 - 例如1 天 - 你生活在一个更极端的时区 - 例如奥克兰 UCT+13.

当然,一旦您向 RRD 写入任何内容,lastupdate 就会发生变化,并且 RRA 会根据需要添加许多新点(当然会删除旧点)。