Recreate a follower index

Recreate a follower index

When a document is updated or deleted, the underlying operation is retained in the Lucene index for a period of time defined by the index.soft_deletes.retention_lease.period parameter. You configure this setting on the leader index.

When a follower index starts, it acquires a retention lease from the leader index. This lease informs the leader that it should not allow a soft delete to be pruned until either the follower indicates that it has received the operation, or until the lease expires.

If a follower index falls sufficiently behind a leader and cannot replicate operations, Elasticsearch reports an indices[].fatal_exception error. To resolve the issue, recreate the follower index. When the new follow index starts, the remote recovery process recopies the Lucene segment files from the leader.

Recreating the follower index is a destructive action. All existing Lucene segment files are deleted on the cluster containing the follower index.

To recreate a follower index, access Cross-Cluster Replication and choose the Follower indices tab.

Select the follower index and pause replication. When the follower index status changes to Paused, reselect the follower index and choose to unfollow the leader index.

The follower index will be converted to a standard index and will no longer display on the Cross-Cluster Replication page.

In the side navigation, choose Index Management. Select the follower index from the previous steps and close the follower index.

You can then recreate the follower index to restart the replication process.

Use the API

Use the pause follow API to pause the replication process. Then, close the follower index and recreate it. For example:

  1. resp = client.ccr.pause_follow(
  2. index="follower_index",
  3. )
  4. print(resp)
  5. resp1 = client.indices.close(
  6. index="follower_index",
  7. )
  8. print(resp1)
  9. resp2 = client.ccr.follow(
  10. index="follower_index",
  11. wait_for_active_shards="1",
  12. remote_cluster="remote_cluster",
  13. leader_index="leader_index",
  14. )
  15. print(resp2)
  1. response = client.ccr.pause_follow(
  2. index: 'follower_index'
  3. )
  4. puts response
  5. response = client.indices.close(
  6. index: 'follower_index'
  7. )
  8. puts response
  9. response = client.ccr.follow(
  10. index: 'follower_index',
  11. wait_for_active_shards: 1,
  12. body: {
  13. remote_cluster: 'remote_cluster',
  14. leader_index: 'leader_index'
  15. }
  16. )
  17. puts response
  1. const response = await client.ccr.pauseFollow({
  2. index: "follower_index",
  3. });
  4. console.log(response);
  5. const response1 = await client.indices.close({
  6. index: "follower_index",
  7. });
  8. console.log(response1);
  9. const response2 = await client.ccr.follow({
  10. index: "follower_index",
  11. wait_for_active_shards: 1,
  12. remote_cluster: "remote_cluster",
  13. leader_index: "leader_index",
  14. });
  15. console.log(response2);
  1. POST /follower_index/_ccr/pause_follow
  2. POST /follower_index/_close
  3. PUT /follower_index/_ccr/follow?wait_for_active_shards=1
  4. {
  5. "remote_cluster" : "remote_cluster",
  6. "leader_index" : "leader_index"
  7. }