Searchable snapshot

Searchable snapshot

Phases allowed: hot, cold, frozen.

Takes a snapshot of the managed index in the configured repository and mounts it as a searchable snapshot. If the index is part of a data stream, the mounted index replaces the original index in the stream.

The searchable_snapshot action requires data tiers. The action uses the index.routing.allocation.include._tier_preference setting to mount the index directly to the phase’s corresponding data tier. In the frozen phase, the action mounts a partially mounted index prefixed with partial- to the frozen tier. In other phases, the action mounts a fully mounted index prefixed with restored- to the corresponding data tier.

In the frozen tier, the action will ignore the setting index.routing.allocation.total_shards_per_node, if it was present in the original index, to account for the difference in the number of nodes between the frozen and the other tiers. To set index.routing.allocation.total_shards_per_node for searchable snapshots, set the total_shards_per_node option in the frozen phase’s searchable_snapshot action within the ILM policy.

Don’t include the searchable_snapshot action in both the hot and cold phases. This can result in indices failing to automatically migrate to the cold tier during the cold phase.

If the searchable_snapshot action is used in the hot phase the subsequent phases cannot include the shrink or forcemerge actions.

This action cannot be performed on a data stream’s write index. Attempts to do so will fail. To convert the index to a searchable snapshot, first manually roll over the data stream. This creates a new write index. Because the index is no longer the stream’s write index, the action can then convert it to a searchable snapshot. Using a policy that makes use of the rollover action in the hot phase will avoid this situation and the need for a manual rollover for future managed indices.

Mounting and relocating the shards of searchable snapshot indices involves copying the shard contents from the snapshot repository. This may incur different costs from the copying between nodes that happens with regular indices. These costs are typically lower but, in some environments, may be higher. See Reduce costs with searchable snapshots for more details.

By default, this snapshot is deleted by the delete action in the delete phase. To keep the snapshot, set delete_searchable_snapshot to false in the delete action. This snapshot retention runs off the index lifecycle management (ILM) policies and is not effected by snapshot lifecycle management (SLM) policies.

Options

snapshot_repository

(Required, string) Repository used to store the snapshot.

force_merge_index

(Optional, Boolean) Force merges the managed index to one segment. Defaults to true. If the managed index was already force merged using the force merge action in a previous action the searchable snapshot action force merge step will be a no-op.

Shards that are relocating during a forcemerge will not be merged. The searchable_snapshot action will continue executing even if not all shards are force merged.

This force merging occurs in the phase that the index is in prior to the searchable_snapshot action. For example, if using a searchable_snapshot action in the hot phase, the force merge will be performed on the hot nodes. If using a searchable_snapshot action in the cold phase, the force merge will be performed on whatever tier the index is prior to the cold phase (either hot or warm).

total_shards_per_node

The maximum number of shards (replicas and primaries) that will be allocated to a single node for the searchable snapshot index. Defaults to unbounded.

Examples

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "cold": {
  6. "actions": {
  7. "searchable_snapshot": {
  8. "snapshot_repository": "backing_repo"
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. cold: {
  6. actions: {
  7. searchable_snapshot: {
  8. snapshot_repository: "backing_repo",
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "cold": {
  6. "actions": {
  7. "searchable_snapshot" : {
  8. "snapshot_repository" : "backing_repo"
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }