高级客户端的主要目的是公开API特定的方法,这些方法接受请求对象作为参数并返回响应对象,以便请求编组和响应解编组由客户端本身处理。
每个API可以同步或异步调用。同步方法返回一个响应对象,而名称以async后缀结尾的异步方法则需要一个侦听器参数,一旦收到响应或错误,该参数将被通知(在低级客户端管理的线程池上)。
Java高级REST客户端取决于Elasticsearch核心项目。它接受与相同的请求参数,TransportClient并返回相同的响应对象。
添加依赖:
<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>7.6.2</version>
</dependency>
由于我使用的springboot版本对应的是6.8.5,所以maven中还要添加
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<elasticsearch.version>7.6.2</elasticsearch.version>
</properties>
初始化:
@Configuration
public class ESClient {
@Bean
public RestHighLevelClient client(){
RestHighLevelClient client = new RestHighLevelClient(
RestClient.builder(
// new HttpHost("321.321.321.321", 9201, "http"),
new HttpHost("123.123.123.123", 9200, "http")));
return client;
}
}