Data Lifecycle

Measures and Streams

Due to the design of BanyanDB, the data in the Measures and Streams can not be deleted directly. The data will be deleted automatically based on the Groups TTL setting.

The TTL means the time to live of the data in the group. Each group has an internal trigger which is triggered by writing events. If there is no further data, the expired data can’t get removed.

For example, the following command will create a group with a TTL of 7 days:

bydbctl group create -f - <<EOF
metadata:
  name: sw_metric
catalog: CATALOG_MEASURE
resource_opts:
  shard_num: 2
  segment_interval:
    unit: UNIT_DAY
    num: 1
  ttl:
    unit: UNIT_DAY
    num: 7
EOF

The data in this group will keep 7 days.

If you want to change the TTL of the data in this group to be 1 day, use the command:

bydbctl group update -f - <<EOF
metadata:
  name: sw_metric
catalog: CATALOG_MEASURE
resource_opts:
  shard_num: 2
  segment_interval:
    unit: UNIT_DAY
    num: 1
  ttl:
    unit: UNIT_DAY
    num: 1
EOF

More ttl units can be found in the IntervalRule.Unit.

You can also manage the Group by other clients such as Web-UI or Java-Client.

For more details about how they works, please refer to the data rotation.

Property

Property data provides both CRUD operations and TTL mechanism.

The TTL field in a property is used to set the time to live of the property. The property will be deleted automatically after the TTL. It’s a string in the format of “1h”, “2m”, “3s”, “1500ms”. It defaults to 0s, which means the property never expires.

For example, the following command will create a property with a TTL of 1 hour:

bydbctl property apply -f - <<EOF
metadata:
  container:
    group: sw
    name: temp_data
  id: General-Service
tags:
- key: state
  value:
    str:
      value: "failed"
ttl: "1h"
EOF

“General-Service” will be dropped after 1 hour. If you want to extend the TTL, you could use the “keepalive” operation. The “lease_id” is returned in the apply response. You can use get operation to get the property with the lease_id as well.

bydbctl property get -g sw -n temp_data --id General-Service
...
lease_id: 7587880824757265022

The lease_id is used to keep the property alive. You can use keepalive operation to keep the property alive. When the keepalive operation is called, the property’s TTL will be reset to the original value.

bydbctl property keepalive --lease_id 7587880824757265022

“General-Service” lives another 1 hour.

You can also manage the Property by other clients such as Web-UI or Java-Client.

The API reference