Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/399.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
ElasticSearch java API使用项id跨索引(使用别名)获取多个文档_Java_Amazon Web Services_<img Src="//i.stack.imgur.com/RUiNP.png" Height="16" Width="18" Alt="" Class="sponsor Tag Img">elasticsearch_Kibana_Elasticsearch Jest - Fatal编程技术网 elasticsearch,kibana,elasticsearch-jest,Java,Amazon Web Services,elasticsearch,Kibana,Elasticsearch Jest" /> elasticsearch,kibana,elasticsearch-jest,Java,Amazon Web Services,elasticsearch,Kibana,Elasticsearch Jest" />

ElasticSearch java API使用项id跨索引(使用别名)获取多个文档

ElasticSearch java API使用项id跨索引(使用别名)获取多个文档,java,amazon-web-services,elasticsearch,kibana,elasticsearch-jest,Java,Amazon Web Services,elasticsearch,Kibana,Elasticsearch Jest,ElasticSearch已经获得了API,我们可以使用该API使用文档Id查询特定文档的单个索引。 从Elasticsearch 5.1中,GET API也支持查询别名上的文档,该别名可以指向以下多个索引: GET /my_alias_name/_search/ { "query": { "bool": { "filter": { "term": { "_id": "AUw

ElasticSearch已经获得了API,我们可以使用该API使用文档Id查询特定文档的单个索引。 从Elasticsearch 5.1中,GET API也支持查询别名上的文档,该别名可以指向以下多个索引:

GET /my_alias_name/_search/
{
        "query": { 
        "bool": {
         "filter": {
                "term": {
                   "_id": "AUwNrOZsm6BwwrmnodbW"
                }
            }
        }
    }
}
实现这一点(使用JestClient…)的相应JAVA API是什么?

1)客户端创建:

JestClientFactory factory = new JestClientFactory();
factory.setHttpClientConfig(new HttpClientConfig.Builder("http://localhost:9200")
                        .multiThreaded(true)
                        .build());
JestClient jestClient = factory.getObject();
2) 准备搜索请求:

SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
searchSourceBuilder.query(QueryBuilders.boolQuery().filter(QueryBuilders.termQuery("_id", "AUwNrOZsm6BwwrmnodbW")));

Search search = new Search.Builder(searchSourceBuilder.toString())
                        .addIndex("my_alias_name") -> Add index name or an alias. 
                        .addType("my_type") -> Add index type here. 
                        .build();
3) 执行搜索:

SearchResult result = jestClient.execute(search);
注意:我们可以添加一个别名来代替索引名,它可以正常工作 同样的方式


也许我还不清楚我在想什么。我是专门询问GET API的,因为我假设搜索请求比GET请求的成本更高(任何请求都只在文档_id上)!如果我错了,请纠正我。为了清楚起见,您在问题中提到的请求是搜索API而不是Get API。即使您使用别名Get/my_alias\u name/my_type/my_id执行Get请求,也会返回文档。正如我提到的,我正在查询可以指向多个索引的别名,所以可以有多个文档匹配同一个文档_id。不,获取/my_alias_name/my_type/my_id错误如下:{“error”:“ElasticsearchIllegalArgumentException[alias[data]有多个与其相关联的索引[[index_1,index_2]],无法执行单个索引op],“status”:400}好的,我明白了。是的,GET请求失败并出现错误的说法是正确的,因为在您的例子中,别名指向多个索引。我没有想到那件事会为此道歉。但您的问题是“从Elasticsearch 5.1开始,GET API也支持查询别名上的文档,可以指向这样的多个索引”--搜索查询--“实现这一点的相应JAVA API是什么(使用JestClient…?)