Ao tentar restaurar índices a partir de snapshots manuais no Amazon OpenSearch Service, a restauração falha com uma mensagem de erro.
Resolução
O Amazon OpenSearch Service monitora o índice .kibana e recria o índice quando ele é excluído. Esse comportamento pode fazer com que a restauração falhe com a seguinte mensagem de erro:
{
"error": {
"root_cause": [{
"type": "snapshot_restore_exception",
"reason": "[repository-name:snapshot-name/1A2B34aZQFWQpFOYYJfxmQ] cannot restore index [.kibana] because an open index with same name already exists in the cluster. Either close or delete the existing index or restore the index under a different name by providing a rename pattern and replacement name"
}],
"type": "snapshot_restore_exception",
"reason": "[repository-name:snapshot-name/1A2B34aZQFWQpFOYYJfxmQ] cannot restore index [.kibana] because an open index with same name already exists in the cluster. Either close or delete the existing index or restore the index under a different name by providing a rename pattern and replacement name"
},
"status": 500
}
Para resolver esse problema, execute as seguintes etapas:
1. Restaure os índices e renomeie o índice .kibana da seguinte maneira:
# restore indices. $ curl -XPOST -H 'Content-Type: application/json' 'https://your-domain-end-point/_snapshot/your-repository-name/your-snapshot-name/_restore' -d'
{
"indices": "*",
"ignore_unavailable": true,
"include_global_state": false,
"rename_pattern": ".kibana",
"rename_replacement": "restored_.kibana"
}
Neste exemplo, o índice .kibana foi renomeado para “restored\ _.kibana”.
2. Use a operação de API \ _reindex para renomear “restored\ _.kibana” novamente para “.kibana” da seguinte maneira:
# reindex restored_.kibana to .kibana
$ curl -XPOST -H 'Content-Type: application/json' 'https://your-domain-end-point/_reindex' -d'
{
"source": {
"index": "restored_.kibana"
},
"dest": {
"index": ".kibana"
}
}
Agora você pode restaurar seus índices a partir de um snapshot manual.