How to erase ElasticSearch index?

后端 未结 4 1837
轻奢々
轻奢々 2021-02-01 16:57

My unit/integration tests includes tests for search functionality.

My idea is to have empty search index before each test. So, I\'m trying to remove al

相关标签:
4条回答
  • 2021-02-01 17:02

    First of all you don't have to clear all data by issuing a delete on each doc id. You can just delete all data with delete by query matching all documents http://www.elasticsearch.org/guide/reference/api/delete-by-query.html Having that said I don't recommend that either, because it's not recommended to do this often on large doc collections (see docs).

    What you really want to do is delete the whole index (it's fast) http://www.elasticsearch.org/guide/reference/api/admin-indices-delete-index.html , recreate it, put in data and this is important refresh the index to "commit" the changes and make them visible. http://www.elasticsearch.org/guide/reference/api/admin-indices-refresh.html

    I do this in my tests and never had a problem.

    0 讨论(0)
  • 2021-02-01 17:22
    1. it is not the async call (you can add a listener and avoid actionGet to get the async call)
    2. delete all items via:

      client.prepareDeleteByQuery(indexName).
                  setQuery(QueryBuilders.matchAllQuery()).
                  setTypes(indexType).
                  execute().actionGet();
      
    3. refresh your index to see the changes (only required in unit tests)

    0 讨论(0)
  • 2021-02-01 17:23

    Found solution:

    IndicesAdminClient adminClient = searchConnection.client.admin().indices();
    String indexName = "location";
    DeleteIndexResponse delete = adminClient.delete(new DeleteIndexRequest(indexName)).actionGet()
    if (!delete.isAcknowledged()) {
        log.error("Index {} wasn't deleted", indexName);
    }
    

    and

    client.admin().indices().flush(new FlushRequest('location')).actionGet();
    

    after putting new data into index.

    0 讨论(0)
  • 2021-02-01 17:24

    My idea is to have empty search index before each test

    So create a new index at the start of the test, don't re-use the old one. You're guaranteed an empty one then. In the tests's teardown, you can then delete the test index.

    It there any way to commit last changes, or make an lock until all data will be written?

    No, ElasticSearch has no transactions or locking.

    If you don't want to create new index each time, then try adding a loop which checks to see if the index is empty, then waits and tries again, until it is.

    0 讨论(0)
提交回复
热议问题