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
}



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

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

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


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