Set the lifecycle of a data stream

Set the lifecycle of a data stream

New API reference

For the most up-to-date API details, refer to Data stream APIs.

Configures the data stream lifecycle for the targeted data streams.

Prerequisites

If the Elasticsearch security features are enabled, you must have the manage_data_stream_lifecycle index privilege or higher to use this API. For more information, see Security privileges.

Request

PUT _data_stream/<data-stream>/_lifecycle

Description

Configures the data stream lifecycle for the targeted data streams. If multiple data streams are provided but at least one of them does not exist, then the update of the lifecycle will fail for all of them and the API will respond with 404.

Path parameters

<data-stream>

(Required, string) Comma-separated list of data streams used to limit the request. Supports wildcards (*). To target all data streams use * or _all.

Query parameters

expand_wildcards

(Optional, string) Type of data stream that wildcard patterns can match. Supports comma-separated values, such as open,hidden. Valid values are:

  • all, hidden

    Match any data stream, including hidden ones.

    open, closed

    Matches any non-hidden data stream. Data streams cannot be closed.

    none

    Wildcard patterns are not accepted.

Defaults to open.

Request body

lifecycle

(Required, object)

Properties of lifecycle

  • data_retention

    (Optional, string) If defined, every document added to this data stream will be stored at least for this time frame. Any time after this duration the document could be deleted. When empty, every document in this data stream will be stored indefinitely.

    enabled

    (Optional, boolean) If defined, it turns data stream lifecycle on/off (true/false) for this data stream. A data stream lifecycle that’s disabled (enabled: false) will have no effect on the data stream. Defaults to true.

    downsampling

    (Optional, array) An optional array of downsampling configuration objects, each defining an after interval representing when the backing index is meant to be downsampled (the time frame is calculated since the index was rolled over, i.e. generation time) and a fixed_interval representing the downsampling interval (the minimum fixed_interval value is 5m). A maximum number of 10 downsampling rounds can be configured. See configuration example below.

Examples

The following example sets the lifecycle of my-data-stream:

  1. resp = client.indices.put_data_lifecycle(
  2. name="my-data-stream",
  3. data_retention="7d",
  4. )
  5. print(resp)
  1. response = client.indices.put_data_lifecycle(
  2. name: 'my-data-stream',
  3. body: {
  4. data_retention: '7d'
  5. }
  6. )
  7. puts response
  1. const response = await client.indices.putDataLifecycle({
  2. name: "my-data-stream",
  3. data_retention: "7d",
  4. });
  5. console.log(response);
  1. PUT _data_stream/my-data-stream/_lifecycle
  2. {
  3. "data_retention": "7d"
  4. }

When the lifecycle is successfully updated in all data streams, you receive the following result:

  1. {
  2. "acknowledged": true
  3. }

Examples

The following example configures two downsampling rounds, the first one starting one day after the backing index is rolled over (or later, if the index is still within its write-accepting time bounds) with an interval of 10m, and a second round starting 7 days after rollover at an interval of 1d:

  1. resp = client.indices.put_data_lifecycle(
  2. name="my-weather-sensor-data-stream",
  3. downsampling=[
  4. {
  5. "after": "1d",
  6. "fixed_interval": "10m"
  7. },
  8. {
  9. "after": "7d",
  10. "fixed_interval": "1d"
  11. }
  12. ],
  13. )
  14. print(resp)
  1. response = client.indices.put_data_lifecycle(
  2. name: 'my-weather-sensor-data-stream',
  3. body: {
  4. downsampling: [
  5. {
  6. after: '1d',
  7. fixed_interval: '10m'
  8. },
  9. {
  10. after: '7d',
  11. fixed_interval: '1d'
  12. }
  13. ]
  14. }
  15. )
  16. puts response
  1. const response = await client.indices.putDataLifecycle({
  2. name: "my-weather-sensor-data-stream",
  3. downsampling: [
  4. {
  5. after: "1d",
  6. fixed_interval: "10m",
  7. },
  8. {
  9. after: "7d",
  10. fixed_interval: "1d",
  11. },
  12. ],
  13. });
  14. console.log(response);
  1. PUT _data_stream/my-weather-sensor-data-stream/_lifecycle
  2. {
  3. "downsampling": [
  4. {
  5. "after": "1d",
  6. "fixed_interval": "10m"
  7. },
  8. {
  9. "after": "7d",
  10. "fixed_interval": "1d"
  11. }
  12. ]
  13. }