es的java调用

Elasticsearch Java 客户端调用方法

Elasticsearch 提供了两种主要的 Java 客户端调用方式:High Level REST Client (官方推荐)和 Java API Client(8.x 版本后新增)。以下分别介绍两种方式的使用方法。


High Level REST Client(7.x-8.x 兼容)

适用于 Elasticsearch 7.x 和 8.x 版本,需添加 Maven 依赖:

XML 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>7.17.0</version>
</dependency>

初始化客户端

java 复制代码
RestHighLevelClient client = new RestHighLevelClient(
    RestClient.builder(new HttpHost("localhost", 9200, "http"))
);

索引文档

java 复制代码
IndexRequest request = new IndexRequest("index_name")
    .id("1")
    .source("field1", "value1", "field2", "value2");
IndexResponse response = client.index(request, RequestOptions.DEFAULT);

搜索文档

java 复制代码
SearchRequest searchRequest = new SearchRequest("index_name");
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(QueryBuilders.matchQuery("field1", "value1"));
searchRequest.source(sourceBuilder);
SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);

Java API Client(8.x+ 推荐)

Elasticsearch 8.x 推出的新客户端,需添加依赖:

XML 复制代码
<dependency>
    <groupId>co.elastic.clients</groupId>
    <artifactId>elasticsearch-java</artifactId>
    <version>8.12.0</version>
</dependency>

初始化客户端

java 复制代码
RestClient restClient = RestClient.builder(
    new HttpHost("localhost", 9200)).build();
ElasticsearchTransport transport = new RestClientTransport(restClient, new JacksonJsonpMapper());
ElasticsearchClient client = new ElasticsearchClient(transport);

索引文档

java 复制代码
Product product = new Product("1", "Elasticsearch Guide");
IndexResponse response = client.index(i -> i
    .index("products")
    .id(product.getId())
    .document(product));

搜索文档

java 复制代码
SearchResponse<Product> response = client.search(s -> s
    .index("products")
    .query(q -> q
        .match(t -> t
            .field("name")
            .query("Guide"))),
    Product.class);

通用注意事项

  1. 连接池管理:确保客户端单例化,避免重复创建。
  2. 异常处理 :捕获 IOExceptionElasticsearchException
  3. 版本兼容性:客户端版本应与 Elasticsearch 服务端主版本号一致。
  4. 异步操作 :两种客户端均支持异步调用(如 client.indexAsync())。

示例代码完整结构

java 复制代码
// 关闭客户端(finally 块中调用)
client.close();

两种方式均可实现完整 CRUD 操作,8.x 用户建议优先使用新 Java API Client 以获得更好的类型安全和流畅 API 体验。

相关推荐
大数据新鸟19 小时前
操作系统之虚拟内存
java·服务器·网络
Tong Z19 小时前
常见的限流算法和实现原理
java·开发语言
凭君语未可19 小时前
Java 中的实现类是什么
java·开发语言
He少年19 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
克里斯蒂亚诺更新19 小时前
myeclipse的pojie
java·ide·myeclipse
迷藏49420 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏49420 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
qq_4335021820 小时前
Codex cli 飞书文档创建进阶实用命令 + Skill 创建&使用 小白完整教程
java·前端·飞书
safestar201220 小时前
ES批量写入性能调优:BulkProcessor 参数详解与实战案例
java·大数据·运维·jenkins
还在忙碌的吴小二20 小时前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring