Multi Search Template

多搜索(Multi Search)模板 API 允许使用_msearch/template端点在同一个API中执行多个搜索模板请求。

以下请求形式与Multi Search API形式相似:

header\n
body\n
header\n
body\n

header部分与一般的Multi Search API支持相同的indextypessearch_typepreferencerouting选项。

body部分包含一个搜索模板body请求,并且支持inline,存储和文件模板。比如:

$ cat requests
{"index": "test"}
{"inline": {"query": {"match":  {"user" : "{{username}}" }}}, "params": {"username": "john"}} # ①
{"index": "_all", "types": "accounts"}
{"inline": {"query": {"{{query_type}}": {"name": "{{name}}" }}}, "params": {"query_type": "match_phrase_prefix", "name": "Smith"}}
{"index": "_all"}
{"id": "template_1", "params": {"query_string": "search for these words" }} # ②
{"types": "users"}
{"file": "template_2", "params": {"field_name": "fullname", "field_value": "john smith" }} # ③

$ curl -XGET localhost:9200/_msearch/template --data-binary "@requests"; echo

inline搜索模板请求

② 基于存储模板的搜索模板请求

③ 基于文件模板的搜索模板请求

响应返回一个responses数组,其中包括每个搜索模板请求的搜索模板响应,该响应匹配其在原始多搜索模板请求中的顺序。如果该特定搜索模板请求的完全失败,将返回error消息的对象,而不是实际的搜索响应。

Last updated