问题描述:
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即可。