Elasticsearch(ES)(版本7.x)数据更新后刷新策略RefreshPolicy
介绍:
ES数据写入后,默认1s后才会被搜索到(refresh_interval为1);
这样可能是考虑到性能问题,毕竟实时IO 消耗较多资源
造成的现象:
例如一个索引现在有100个文档,当新增一个文档时,立即查询,显示数量为100,并不为101
例如当修改一个文档数据后,立即查询的结果为上次文档的数据,并不为最新数据
刷新策略RefreshPolicy:
IMMEDIATE:
- 请求提交数据后,立即进行数据刷新,再结束请求
- 优点:实时性高、操作延时短
- 缺点:资源消耗高
WAIT_UNTIL:
- 请求提交数据后,等待数据完成刷新(1s),再结束请求
- 优点:实时性高、操作延时长
- 缺点:资源消耗低
NONE:(默认策略)
- 请求提交数据后,不等待数据刷新,直接结束请求
- 优点:操作延时短、资源消耗低
- 缺点:实时性低
支持的接口:
删除:DeleteRequestBuilder
新增:IndexRequestBuilder
更新:UpdateRequestBuilder
批量:BulkRequestBuilder
用法:(elasticsearch-rest-high-level-client)
requestBuilder.setRefreshPolicy(WriteRequest.RefreshPolicy.IMMEDIATE);// 立即更新
结束