让 Elasticsearch Delete By Query 请求立即生效

让 Elasticsearch Delete By Query 请求立即生效

在 Elasticsearch 中,Delete By Query 操作默认是近实时的(near real-time),这意味着删除操作可能不会立即对搜索可见。要让删除操作立即生效,你可以使用以下几种方法:

1. 使用 refresh 参数

在请求中设置 refresh 参数为 truewait_for

go 复制代码
req := esapi.DeleteByQueryRequest{
    Index:      []string{doc.IndexName()},
    Body:       strings.NewReader(string(body)),
    Refresh:    esapi.BoolPtr(true), // 立即刷新
    // 或者使用 wait_for 让操作在刷新后返回
    // Refresh:    esapi.StringPtr("wait_for"),
}

2. 手动刷新索引

执行删除操作后,立即刷新相关索引:

go 复制代码
// 执行删除操作
res, err := req.Do(context.Background(), client)
if err != nil {
    // 处理错误
}
defer res.Body.Close()

// 手动刷新索引
refreshReq := esapi.IndicesRefreshRequest{
    Index: []string{doc.IndexName()},
}
refreshRes, err := refreshReq.Do(context.Background(), client)
if err != nil {
    // 处理错误
}
defer refreshRes.Body.Close()

3. 配置索引的刷新间隔

如果你经常需要实时操作,可以考虑将索引的刷新间隔设置为1秒(默认值):

json 复制代码
PUT /your_index/_settings
{
  "index.refresh_interval": "1s"
}

或者完全禁用自动刷新,改为手动控制:

json 复制代码
PUT /your_index/_settings
{
  "index.refresh_interval": "-1"
}

4. 使用 ?refresh URL 参数

如果你使用的是 REST API 而不是 Go 客户端,可以在 URL 中添加 ?refresh 参数:

复制代码
POST /your_index/_delete_by_query?refresh
{
  "query": { ... }
}

最佳实践建议

  1. 对于生产环境,频繁的刷新操作会影响性能,建议:

    • 批量操作时使用 refresh=wait_for
    • 对实时性要求高的单次操作使用 refresh=true
    • 大多数情况下依赖默认的刷新机制
  2. 如果你正在执行大量删除操作,考虑在操作完成后执行一次手动刷新,而不是每次删除都刷新。

  3. 注意 refresh=true 会立即创建新的段文件,可能导致更多的段合并操作,从而影响集群性能。

相关推荐
Hello.Reader1 小时前
Flink SQL UPDATE 语句批模式行级更新、连接器能力要求与实战避坑
大数据·sql·flink
毕设源码-赖学姐1 小时前
【开题答辩全过程】以 基于Spark的电商用户行为分析系统为例,包含答辩的问题和答案
大数据·分布式·spark
图导物联1 小时前
商场室内导航系统:政策适配 + 技术实现 + 代码示例,打通停车逛店全流程
大数据·人工智能·物联网
牛奔2 小时前
git本地提交后,解决push被拒绝 error: failed to push some refs to
大数据·git·elasticsearch·搜索引擎·全文检索
梦里不知身是客112 小时前
doris的优化器策略介绍
大数据
暗之星瞳3 小时前
mysql表的链接
大数据·数据库·mysql
凤凰战士芭比Q3 小时前
Jenkins(Pipeline job)
java·servlet·jenkins
武子康3 小时前
大数据-191 Elasticsearch 集群规划与调优:节点角色、分片副本、写入与搜索优化清单
大数据·后端·elasticsearch
jason成都3 小时前
jetlinks-扩展TDengine时序库
大数据·时序数据库·tdengine