qq_61294100 2023-03-04 18:55 采纳率: 76%
浏览 28
已结题

elasticsearch使用scroll滚动查询出错,找不到原因

问题描述:
ElasticSearch使用scroll报错

代码:

#scroll
#第一次查询
POST /my_index/_search?scroll=1m
{
  "query": {
    "match_all": {}
  },
  "size": 1
}
#第二次查询 
GET /_search/scroll?scroll=1m
{
  "_scroll_id" : "FGluY2x1ZGVfY29udGV4dF91dWlkDXF1ZXJ5QW5kRmV0Y2gBFFZRSXRxNFlCeWJGWHdURVVMcXgyAAAAAAAAFLoWMExxdV92SXRTOHE2WUpnaWZwT0h6UQ=="
  
}

报错内容:

{
  "error" : {
    "root_cause" : [
      {
        "type" : "illegal_argument_exception",
        "reason" : "Unknown parameter [_scroll_id] in request body or parameter is of the wrong type[VALUE_STRING] "
      }
    ],
    "type" : "illegal_argument_exception",
    "reason" : "Unknown parameter [_scroll_id] in request body or parameter is of the wrong type[VALUE_STRING] "
  },
  "status" : 400
}



  • 写回答

1条回答 默认 最新

  • 「已注销」 2023-03-04 19:01
    关注

    “Devil组”引证GPT后的撰写:
    似乎是第二次使用scroll查询时,请求参数_scroll_id无法被识别,导致了参数错误的异常。

    请检查第二次查询请求中的语法是否正确,正确的语法应该是:

    POST /_search/scroll
    {
      "scroll": "1m",
      "scroll_id": "FGluY2x1ZGVfY29udGV4dF91dWlkDXF1ZXJ5QW5kRmV0Y2gBFFZRSXRxNFlCeWJGWHdURVVMcXgyAAAAAAAAFLoWMExxdV92SXRTOHE2WUpnaWZwT0h6UQ=="
    }
    
    
    

    第二次查询中,应该使用POST方法,同时在请求体中携带scroll_id参数和对应的值。另外,由于第二次查询的API中包含了_search,可以省略掉之前的index名称,直接使用/_search/scroll即可。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月12日
  • 已采纳回答 3月4日
  • 创建了问题 3月4日