Time to Live (TTL)

This section describes how the TTL mechanism works and what its limits are. It also gives examples of commands and code snippets that can be used to enable, configure, and disable TTL.

How it works

YDB lets you specify a table column (TTL column), whose values set the lifetime of items. TTL automatically deletes the item from your table once the specified number of seconds passes after the time set in the TTL column.

Warning

An item with the NULL value in the TTL column is never deleted.

The timestamp for deleting a table item is determined by the formula:

  1. expiration_time = valueof(ttl_column) + expire_after_seconds

Time to Live (TTL) - 图1

Note

TTL doesn’t guarantee that the item will be deleted exactly at expiration_time, it might happen later. If it’s important to exclude logically obsolete but not yet physically deleted items from the selection, use query-level filtering.

Data is deleted by the Background Removal Operation (BRO), consisting of two stages:

  1. Checking the values in the TTL column.
  2. Deleting expired data.

The BRO has the following properties:

Guarantees

  • At every point in time, a BRO is run in no more than 1 instance per table.
  • BROs are run no more than once per hour for the same shard.
  • Data consistency is guaranteed. The TTL column value is re-checked during the delete stage. This means that if the TTL column value is updated between stages 1 and 2 (for example, with UPDATE) and ceases to meet the delete criteria, the row will not be deleted.

Limitations

  • The TTL column must be of one of the following types:
    • Date
    • Datetime
    • Timestamp
    • Uint32
    • Uint64
    • DyNumber
  • The value in the TTL column with a numeric type (Uint32, Uint64, DyNumber) is interpreted as a Unix-time value specified in:
    • Seconds
    • Milliseconds
    • Microseconds
    • Nanoseconds
  • You can’t specify multiple TTL columns.
  • You can’t delete the TTL column. However, if this is required, you should first disable TTL for the table.

Setup

Currently, you can manage TTL settings using:

Note

TTL setup using YQL is possible for the Date, Datetime, and Timestamp columns.

Enabling TTL for an existing table

In the example below, the items of the mytable table will be deleted an hour after the time set in the created_at column:

YQL

CLI

C++

Python

  1. ALTER TABLE `mytable` SET (TTL = Interval("PT1H") ON created_at);

Time to Live (TTL) - 图2

  1. $ ydb -e <endpoint> -d <database> table ttl set --column created_at --expire-after 3600 mytable

Time to Live (TTL) - 图3

  1. session.AlterTable(
  2. "mytable",
  3. TAlterTableSettings()
  4. .BeginAlterTtlSettings()
  5. .Set("created_at", TDuration::Hours(1))
  6. .EndAlterTtlSettings()
  7. );

Time to Live (TTL) - 图4

  1. session.alter_table('mytable', set_ttl_settings=ydb.TtlSettings().with_date_type_column('created_at', 3600))

Time to Live (TTL) - 图5

Tip

When setting up TTL using YQL, the Interval is created from a string literal in ISO 8601.

Enabling TTL for a newly created table

For a newly created table, you can pass TTL settings along with the table description:

YQL

C++

Python

  1. CREATE TABLE `mytable` (
  2. id Uint64,
  3. expire_at Timestamp,
  4. PRIMARY KEY (id)
  5. ) WITH (
  6. TTL = Interval("PT0S") ON expire_at
  7. );

Time to Live (TTL) - 图6

  1. session.CreateTable(
  2. "mytable",
  3. TTableBuilder()
  4. .AddNullableColumn("id", EPrimitiveType::Uint64)
  5. .AddNullableColumn("expire_at", EPrimitiveType::Timestamp)
  6. .SetPrimaryKeyColumn("id")
  7. .SetTtlSettings("expire_at")
  8. .Build()
  9. );

Time to Live (TTL) - 图7

  1. session.create_table(
  2. 'mytable',
  3. ydb.TableDescription()
  4. .with_column(ydb.Column('id', ydb.OptionalType(ydb.DataType.Uint64)))
  5. .with_column(ydb.Column('expire_at', ydb.OptionalType(ydb.DataType.Timestamp)))
  6. .with_primary_key('id')
  7. .with_ttl(ydb.TtlSettings().with_date_type_column('expire_at'))
  8. )

Time to Live (TTL) - 图8

Disabling TTL

YQL

CLI

C++

Python

  1. ALTER TABLE `mytable` RESET (TTL);

Time to Live (TTL) - 图9

  1. $ ydb -e <endpoint> -d <database> table ttl drop mytable

Time to Live (TTL) - 图10

  1. session.AlterTable(
  2. "mytable",
  3. TAlterTableSettings()
  4. .BeginAlterTtlSettings()
  5. .Drop()
  6. .EndAlterTtlSettings()
  7. );

Time to Live (TTL) - 图11

  1. session.alter_table('mytable', drop_ttl_settings=True)

Time to Live (TTL) - 图12

Getting TTL settings

The current TTL settings can be obtained from the table description:

CLI

C++

Python

  1. $ ydb -e <endpoint> -d <database> scheme describe mytable

Time to Live (TTL) - 图13

  1. auto desc = session.DescribeTable("mytable").GetValueSync().GetTableDescription();
  2. auto ttl = desc.GetTtlSettings();

Time to Live (TTL) - 图14

  1. desc = session.describe_table('mytable')
  2. ttl = desc.ttl_settings

Time to Live (TTL) - 图15