Loading

Tutorial: Update the lifecycle of a data stream

Serverless Stack

Follow these steps to configure or remove data stream lifecycle settings for an existing, individual data stream:

Note that these steps are for data stream lifecycle only. For the steps to configure index lifecycle management, refer to the ILM documentation. For a comparison between the two, refer to Data lifecycle.

To add or to change the retention period of your data stream you can use the Index Management tools in Kibana or the Elasticsearch lifecycle API.

To change the data retention settings for a data stream:

  1. Go to the Index Management page using the navigation menu or the global search field.

  2. Open the Data Streams tab.

  3. Use the search tool to find the data stream you're looking for.

  4. Select the data stream to view its details.

  5. In the data stream details pane, select Manage > Edit data retention to adjust the settings. You can do any of the following:

    • Select how long to retain your data, in days, hours, minutes, or seconds.
    • Choose to Keep data indefinitely, so that your data will not be deleted. Your data stream is still managed but the data will never be deleted. Managing a time series data stream such as for logs or metrics enables Elasticsearch to better store your data even if you do not use a retention period.
    • Disable Enable data retention to turn off data stream lifecycle management for your data stream.

    Note that if the data stream is already managed by ILM, to edit the data retention settings you must edit the associated ILM policy.

To change the data retention settings for a data stream:

  • You can set infinite retention period, meaning that your data should never be deleted. For example:

    				PUT _data_stream/my-data-stream/_lifecycle
    					{ }
    		
    1. An empty payload means that your data stream is still managed but the data will never be deleted. Managing a time series data stream such as for logs or metrics enables Elasticsearch to better store your data even if you do not use a retention period.
  • Or you can set the retention period of your choice. For example:

    				PUT _data_stream/my-data-stream/_lifecycle
    					{
      "data_retention": "30d"
    }
    		
    1. The retention period of this data stream is set to 30 days. This means that Elasticsearch is allowed to delete data that is older than 30 days at its own discretion.

The changes in the lifecycle are applied on all backing indices of the data stream.

You can see the effect of the change in Kibana or using the Elasticsearch explain API:

To check the data retention settings for a data stream:

  1. Go to the Index Management page using the navigation menu or the global search field.
  2. Open the Data Streams tab.
  3. Use the search tool to find the data stream you're looking for.
  4. Select the data stream to view its details. The flyout shows the data retention settings for the data stream. Note that if the data stream is currently managed by an ILM policy, the Effective data retention may differ from the retention value that you've set in the data stream, as indicated by the Data retention.
Index lifecycle status page

To check the data retention settings for a data stream:

				GET .ds-my-data-stream-*/_lifecycle/explain
		

The response will look like:

{
  "indices": {
    ".ds-my-data-stream-2023.04.19-000002": {
      "index": ".ds-my-data-stream-2023.04.19-000002",
      "managed_by_lifecycle": true,
      "index_creation_date_millis": 1681919221417,
      "time_since_index_creation": "6.85s",
      "lifecycle": {
        "enabled": true,
        "data_retention": "30d"
      }
    },
    ".ds-my-data-stream-2023.04.17-000001": {
      "index": ".ds-my-data-stream-2023.04.17-000001",
      "managed_by_lifecycle": true,
      "index_creation_date_millis": 1681745209501,
      "time_since_index_creation": "48d",
      "rollover_date_millis": 1681919221419,
      "time_since_rollover": "6.84s",
      "generation_time": "6.84s",
      "lifecycle": {
        "enabled": true,
        "data_retention": "30d"
      }
    }
  }
}
		
  1. The name of the backing index.
  2. This index is managed by a data stream lifecycle.
  3. The time that has passed since this index has been created.
  4. The data retention for this index is at least 30 days, as it was recently updated.
  5. The name of the backing index.
  6. This index is managed by the built-in data stream lifecycle.
  7. The time that has passed since this index has been created.
  8. The time that has passed since this index was rolled over.
  9. The time that will be used to determine when it’s safe to delete this index and all its data.
  10. The data retention for this index as well is at least 30 days, as it was recently updated.

To remove the lifecycle of a data stream you can use the Index Management tools in Kibana or the Elasticsearch delete lifecycle API.

To remove a data stream's lifecycle:

  1. Go to the Index Management page using the navigation menu or the global search field.

  2. Open the Data Streams tab.

  3. Use the search tool to find the data stream you're looking for.

  4. Select the data stream to view its details.

  5. In the data stream details pane, select Manage > Edit data retention.

  6. Turn off the Enable data retention option and save your changes. The maintenance operations that were applied by the lifecycle will no longer be applied to the data stream and all of its backing indices.

    You can confirm your changes by reopening the data stream pane. The Effective data retention will show a Disabled status.

Index lifecycle status is disabled

To remove a data stream's lifecycle:

				DELETE _data_stream/my-data-stream/_lifecycle
		

After running the API request, the maintenance operations that were applied by the lifecycle will no longer be applied to the data stream and all of its backing indices.

You can then use the explain API again to see that the indices are no longer managed.

				GET .ds-my-data-stream-*/_lifecycle/explain
		
{
  "indices": {
    ".ds-my-data-stream-2023.04.19-000002": {
      "index": ".ds-my-data-stream-2023.04.19-000002",
      "managed_by_lifecycle": false
    },
    ".ds-my-data-stream-2023.04.17-000001": {
      "index": ".ds-my-data-stream-2023.04.19-000001",
      "managed_by_lifecycle": false
    }
  }
}
		
  1. The name of the backing index.
  2. Indication that the index is not managed by the data stream lifecycle.
  3. The name of another backing index.
  4. Indication that the index is not managed by the data stream lifecycle.

Serverless Stack GA 9.2.0

Starting with Elastic Stack version 9.2, the Streams page provides a centralized interface for common data management tasks in Kibana, including getting insight into how your data streams retain data.

  1. Go to the Streams page using the navigation menu or the global search field.
  2. Each stream maps directly to an Elasticsearch data stream. Select a stream to view its details.
  3. Go to the Retention tab to set how long your stream retains data and to get insight into your stream's data ingestion and storage size.
  4. Select Edit data retention and choose to retain your data indefinitely, for a custom period, or by following an existing ILM policy. You can also use the data retention configuration that's set in the index template by enabling the Inherit from index template option. If you use this option, you don't need to specify a custom retention period or policy.

For more information about the retention configuration options, refer to Manage data retention for Streams.