Elasticsearch scroll常见错误

最近使用es嘎嘎报错:

Trying to create too many scroll contexts. Must be less than or equal to: [500]

  • 原因:在search()中设置的timeout时间内,累计生成的scroll_id数超过了最大限制
  • 解决方法:查询scroll以后,删除对应的id,即调用clearScroll方法
            //搜索查询
            $response = $this->client->search($params);
            while (isset($response['hits']['hits']) && count($response['hits']['hits']) > 0) {
     
                //对response内容进行处理
                $scroll_id = $response['_scroll_id'];
                // Execute a Scroll request and repeat
                $response = $this->client->scroll([
                     'scroll_id' => $scroll_id,      //游标id
                     'scroll'    => $timeout         //超时时间
                ]);
     
            }
            //清除scroll_id
            $this->client->clearScroll(array('scroll_id' => $response['_scroll_id']));

作者:Carver-大脸猫

出处:https://www.cnblogs.com/carver/articles/17683678.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

转载请注明原处

posted @   Carver-大脸猫  阅读(1060)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up light_mode palette
选择主题