1

为了确保我的 Elasticsearch 索引具有正确的设置和映射,我有以下代码:

if (client.admin().indices().prepareExists(Index).execute().actionGet().exists()) {            
    client.admin().indices().prepareClose(Index).execute().actionGet();
    client.admin().indices().prepareUpdateSettings(Index).setSettings(settings.string()).execute().actionGet();
    client.admin().indices().prepareOpen(Index).execute().actionGet();
    client.admin().indices().prepareDeleteMapping(Index).setType(Type).execute().actionGet();
    client.admin().indices().preparePutMapping(Index).setType(Type).setSource(mapping).execute().actionGet();
} else {
    client.admin().indices().prepareCreate(Index).addMapping(Type, mapping).setSettings(settings).execute().actionGet();
}

更新设置和映射似乎有点傻,即使它们已经很好了。不过,我不知道如何以更聪明的方式做事。有什么建议么?

非常感谢,

斯廷

4

1 回答 1

4

您可以检索当前设置和映射,并在尝试更新它们之前确保它们是正确的。

ClusterStateResponse response = client.admin().cluster().prepareState()                
    .setFilterAll()
    .setFilterMetaData(false)
    .setFilterIndices(index)
    .execute().actionGet();
IndexMetaData indexMetaData = response.state().metaData().index(index);
Settings settings = indexMetaData.settings();
// Verify settings
MappingMetaData mapping = indexMetaData.mappings().get(type);
// Verify mapping
于 2012-09-11T13:28:18.577 回答