ElasticsearchClient入门指南

在本教程中,我们将探讨如何使用Elasticsearch的官方Java客户端 - ElasticsearchClient。这个强大的工具允许您的Java应用程序与Elasticsearch集群进行交互,执行各种操作,如索引文档、执行搜索查询等。

前提条件

在开始之前,确保您的项目中已经包含了必要的依赖。您可以通过Maven添加以下依赖:

xml 复制代码
<dependency>
    <groupId>co.elastic.clients</groupId>
    <artifactId>elasticsearch-java</artifactId>
    <version>8.10.0</version>
</dependency>
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.3</version>
</dependency>

创建ElasticsearchClient

首先,我们需要创建一个ElasticsearchClient实例。这涉及几个步骤:

  1. 创建一个RestClient实例
  2. 使用RestClient创建一个ElasticsearchTransport实例
  3. 使用transport创建ElasticsearchClient实例

以下是代码示例:

java 复制代码
import co.elastic.clients.elasticsearch.ElasticsearchClient;
import co.elastic.clients.json.jackson.JacksonJsonpMapper;
import co.elastic.clients.transport.ElasticsearchTransport;
import co.elastic.clients.transport.rest_client.RestClientTransport;
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;

// 创建低级客户端
RestClient restClient = RestClient.builder(
    new HttpHost("localhost", 9200)).build();

// 创建传输层
ElasticsearchTransport transport = new RestClientTransport(
    restClient, new JacksonJsonpMapper());

// 创建API客户端
ElasticsearchClient client = new ElasticsearchClient(transport);

执行搜索查询

现在我们有了ElasticsearchClient实例,让我们执行一个简单的搜索查询:

java 复制代码
import co.elastic.clients.elasticsearch._types.query_dsl.MatchQuery;
import co.elastic.clients.elasticsearch.core.SearchResponse;

try {
    // 执行搜索请求
    SearchResponse<Object> response = client.search(s -> s
        .index("my-index")
        .query(q -> q
            .match(new MatchQuery.Builder()
                .field("title")
                .query("elasticsearch")
                .build()
            )
        ),
        Object.class
    );

    // 处理响应
    long totalHits = response.hits().total().value();
    System.out.println("Total hits: " + totalHits);

    // 遍历搜索结果
    response.hits().hits().forEach(hit -> {
        System.out.println("Found document: " + hit.source());
    });

} catch (IOException e) {
    e.printStackTrace();
}

这个例子展示了如何:

  1. 构建一个match查询,搜索标题字段中包含"elasticsearch"的文档
  2. 执行搜索请求
  3. 获取总命中数
  4. 遍历并打印搜索结果

关闭客户端

最后,当您完成所有操作后,别忘了关闭客户端:

java 复制代码
try {
    restClient.close();
} catch (IOException e) {
    e.printStackTrace();
}

结论

本教程介绍了ElasticsearchClient的基本用法。我们学习了如何创建客户端、执行搜索查询和处理结果。ElasticsearchClient提供了丰富的API,允许您执行各种复杂的操作。随着您对Elasticsearch的深入了解,您将能够利用这个客户端执行更高级的查询和操作。

记住,这只是一个起点。Elasticsearch提供了大量的功能,包括聚合、地理空间查询、文档更新等。继续探索官方文档,以充分利用Elasticsearch的强大功能!

相关推荐
独自归家的兔1 分钟前
ubuntu系统安装dbswitch教程 - 备份本地数据到远程服务器
linux·运维·ubuntu
ONE_SIX_MIX4 分钟前
ubuntu 24.04 用rdp连接,桌面黑屏问题,解决
linux·运维·ubuntu
龙飞055 分钟前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
春日见7 分钟前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡15 分钟前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
消失的旧时光-194322 分钟前
Linux 编辑器入门:nano 与 vim 的区别与选择指南
linux·运维·服务器
斯普信专业组23 分钟前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
liu****1 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
池央1 小时前
CANN 诊断工具链深度解析:oam-tools 的自动化故障信息收集、软硬件状态快照与 AI Core 错误溯源机制
运维·人工智能·自动化
云边有个稻草人2 小时前
打工人摸鱼新姿势!轻量斗地主服务器,内网穿透让同事远程联机不翻车
运维·服务器·cpolar