首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

【详解】ElasticSearchJava操作ES实例

  • 25-04-24 14:41
  • 2479
  • 6547
blog.csdn.net

目录

ElasticSearch Java操作ES实例

简介

环境准备

1. 安装 Elasticsearch

2. 添加依赖

连接 Elasticsearch

1. 创建客户端

2. 关闭客户端

基本操作

1. 创建索引

2. 插入数据

3. 查询数据

环境准备

示例代码

代码说明

运行代码

1. 添加依赖

2. 创建客户端

3. 索引文档

4. 查询文档

5. 删除文档

总结


ElasticSearch Java操作ES实例

简介

Elasticsearch 是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景。本文将介绍如何在 Java 应用中使用 Elasticsearch 客户端来连接和操作 Elasticsearch 集群。

环境准备
1. 安装 Elasticsearch

首先,确保你的环境中已经安装了 Elasticsearch。可以从 ​​Elasticsearch 官方网站​​下载最新版本的 Elasticsearch,并按照官方文档进行安装和启动。

2. 添加依赖

在你的 Java 项目中,需要添加 Elasticsearch 的客户端依赖。如果你使用的是 Maven,可以在 ​​pom.xml​​ 文件中添加以下依赖:

  1. <dependency>
  2. <groupId>org.elasticsearch.client</groupId>
  3. <artifactId>elasticsearch-rest-high-level-client</artifactId>
  4. <version>7.10.2</version>
  5. </dependency>

连接 Elasticsearch

1. 创建客户端

使用 ​​RestHighLevelClient​​ 类来创建一个连接到 Elasticsearch 集群的客户端。

  1. import org.elasticsearch.client.RestHighLevelClient;
  2. import org.apache.http.HttpHost;
  3. public class ElasticsearchClient {
  4. public static RestHighLevelClient createClient() {
  5. return new RestHighLevelClient(
  6. RestClient.builder(
  7. new HttpHost("localhost", 9200, "http")
  8. )
  9. );
  10. }
  11. }
2. 关闭客户端

在完成所有操作后,记得关闭客户端以释放资源。

  1. try {
  2. client.close();
  3. } catch (IOException e) {
  4. e.printStackTrace();
  5. }

基本操作

1. 创建索引

创建一个新的索引,并指定一些设置和映射。

  1. import org.elasticsearch.action.admin.indices.create.CreateIndexRequest;
  2. import org.elasticsearch.action.admin.indices.create.CreateIndexResponse;
  3. import org.elasticsearch.client.RequestOptions;
  4. import org.elasticsearch.common.xcontent.XContentType;
  5. public class IndexOperations {
  6. public static void createIndex(RestHighLevelClient client) throws IOException {
  7. CreateIndexRequest request = new CreateIndexRequest("test_index");
  8. request.mapping("{\n" +
  9. " \"properties\": {\n" +
  10. " \"title\": {\n" +
  11. " \"type\": \"text\"\n" +
  12. " },\n" +
  13. " \"content\": {\n" +
  14. " \"type\": \"text\"\n" +
  15. " }\n" +
  16. " }\n" +
  17. "}", XContentType.JSON);
  18. CreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT);
  19. System.out.println("Index created: " + response.isAcknowledged());
  20. }
  21. }
2. 插入数据

向索引中插入一条文档。

  1. import org.elasticsearch.action.index.IndexRequest;
  2. import org.elasticsearch.action.index.IndexResponse;
  3. import org.elasticsearch.common.xcontent.XContentType;
  4. public class DocumentOperations {
  5. public static void indexDocument(RestHighLevelClient client) throws IOException {
  6. String jsonString = "{" +
  7. "\"title\":\"Elasticsearch基础教程\"," +
  8. "\"content\":\"Elasticsearch是一个分布式搜索和分析引擎\"}";
  9. IndexRequest request = new IndexRequest("test_index").source(jsonString, XContentType.JSON);
  10. IndexResponse response = client.index(request, RequestOptions.DEFAULT);
  11. System.out.println("Document indexed with ID: " + response.getId());
  12. }
  13. }
3. 查询数据

从索引中查询文档。

  1. import org.elasticsearch.action.get.GetRequest;
  2. import org.elasticsearch.action.get.GetResponse;
  3. public class SearchOperations {
  4. public static void getDocument(RestHighLevelClient client) throws IOException {
  5. GetRequest request = new GetRequest("test_index", "1");
  6. GetResponse response = client.get(request, RequestOptions.DEFAULT);
  7. if (response.isExists()) {
  8. System.out.println("Document found: " + response.getSourceAsString());
  9. } else {
  10. System.out.println("Document not found.");
  11. }
  12. }
  13. }

通过上述步骤,你可以在 Java 应用中轻松地连接和操作 Elasticsearch 集群。本文介绍了如何创建客户端、创建索引、插入文档和查询文档。这些基本操作为更复杂的使用场景奠定了基础。

以上就是使用 Java 操作 Elasticsearch 的一个简单示例。希望对你有帮助!当然可以!Elasticsearch 是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析、实时应用监控等场景。下面是一个使用 Java 操作 Elasticsearch 的示例代码,包括连接到 ES 集群、创建索引、插入文档、查询文档等基本操作。

环境准备
  1. 添加依赖:在你的 Maven 项目的 ​​pom.xml​​ 文件中添加 Elasticsearch 客户端依赖。
  1. <dependency>
  2. <groupId>org.elasticsearch.client</groupId>
  3. <artifactId>elasticsearch-rest-high-level-client</artifactId>
  4. <version>7.10.2</version>
  5. </dependency>
  1. 配置 Elasticsearch:确保你有一个运行中的 Elasticsearch 实例。你可以使用 Docker 快速启动一个:
docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:7.10.2
示例代码

以下是一个完整的 Java 示例代码,展示了如何连接到 Elasticsearch 集群、创建索引、插入文档和查询文档。

  1. import org.apache.http.HttpHost;
  2. import org.elasticsearch.action.index.IndexRequest;
  3. import org.elasticsearch.action.index.IndexResponse;
  4. import org.elasticsearch.action.search.SearchRequest;
  5. import org.elasticsearch.action.search.SearchResponse;
  6. import org.elasticsearch.client.RequestOptions;
  7. import org.elasticsearch.client.RestClient;
  8. import org.elasticsearch.client.RestHighLevelClient;
  9. import org.elasticsearch.common.xcontent.XContentType;
  10. import org.elasticsearch.index.query.QueryBuilders;
  11. import org.elasticsearch.search.SearchHit;
  12. import org.elasticsearch.search.builder.SearchSourceBuilder;
  13. import java.io.IOException;
  14. import java.util.HashMap;
  15. import java.util.Map;
  16. public class ElasticsearchExample {
  17. public static void main(String[] args) {
  18. // 创建 RestHighLevelClient 客户端
  19. RestHighLevelClient client = new RestHighLevelClient(
  20. RestClient.builder(
  21. new HttpHost("localhost", 9200, "http")
  22. )
  23. );
  24. try {
  25. // 创建索引
  26. createIndex(client);
  27. // 插入文档
  28. insertDocument(client);
  29. // 查询文档
  30. searchDocument(client);
  31. } catch (IOException e) {
  32. e.printStackTrace();
  33. } finally {
  34. // 关闭客户端
  35. try {
  36. client.close();
  37. } catch (IOException e) {
  38. e.printStackTrace();
  39. }
  40. }
  41. }
  42. private static void createIndex(RestHighLevelClient client) throws IOException {
  43. // 创建索引请求
  44. Map<String, Object> mappings = new HashMap<>();
  45. mappings.put("properties", Map.of(
  46. "title", Map.of("type", "text"),
  47. "content", Map.of("type", "text")
  48. ));
  49. String mappingJson = XContentType.JSON.toString(mappings);
  50. IndexRequest indexRequest = new IndexRequest("my_index")
  51. .source(mappingJson, XContentType.JSON);
  52. // 执行请求
  53. IndexResponse indexResponse = client.index(indexRequest, RequestOptions.DEFAULT);
  54. System.out.println("Index created: " + indexResponse.getResult());
  55. }
  56. private static void insertDocument(RestHighLevelClient client) throws IOException {
  57. // 创建文档
  58. Map<String, Object> document = new HashMap<>();
  59. document.put("title", "Elasticsearch Example");
  60. document.put("content", "This is an example of using Elasticsearch with Java.");
  61. // 创建索引请求
  62. IndexRequest indexRequest = new IndexRequest("my_index")
  63. .id("1")
  64. .source(document);
  65. // 执行请求
  66. IndexResponse indexResponse = client.index(indexRequest, RequestOptions.DEFAULT);
  67. System.out.println("Document inserted: " + indexResponse.getResult());
  68. }
  69. private static void searchDocument(RestHighLevelClient client) throws IOException {
  70. // 创建搜索请求
  71. SearchRequest searchRequest = new SearchRequest("my_index");
  72. SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
  73. searchSourceBuilder.query(QueryBuilders.matchQuery("title", "Elasticsearch"));
  74. searchRequest.source(searchSourceBuilder);
  75. // 执行请求
  76. SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
  77. // 处理响应
  78. for (SearchHit hit : searchResponse.getHits().getHits()) {
  79. System.out.println("Document found: " + hit.getSourceAsString());
  80. }
  81. }
  82. }
代码说明
  1. 创建客户端:使用 ​​RestHighLevelClient​​ 连接到 Elasticsearch 集群。
  2. 创建索引:定义索引的映射并创建索引。
  3. 插入文档:创建一个文档并将其插入到指定的索引中。
  4. 查询文档:使用匹配查询(​​matchQuery​​)来搜索包含特定关键字的文档。
运行代码

确保你的 Elasticsearch 实例正在运行,然后运行上述 Java 程序。你应该会看到索引创建、文档插入和查询结果的输出。

希望这个示例对你有帮助!如果有任何问题或需要进一步的帮助,请随时告诉我。当然可以!Elasticsearch 是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析、实时应用监控等场景。在 Java 应用中操作 Elasticsearch 通常需要使用官方提供的客户端库,如 ​​elasticsearch-rest-high-level-client​​(现已停止更新)或更现代的 ​​elasticsearch-java​​ 客户端。

以下是一个详细的步骤和示例代码,展示如何在 Java 中使用 ​​elasticsearch-java​​ 客户端来操作 Elasticsearch 实例:

1. 添加依赖

首先,在你的 ​​pom.xml​​ 文件中添加 Elasticsearch 客户端的依赖。这里以 Maven 为例:

  1. <dependency>
  2. <groupId>co.elastic.clients</groupId>
  3. <artifactId>elasticsearch-java</artifactId>
  4. <version>8.6.2</version> <!-- 请根据实际情况选择合适的版本 -->
  5. </dependency>
2. 创建客户端

创建一个 Elasticsearch 客户端实例,用于与 Elasticsearch 集群进行通信。

  1. import co.elastic.clients.elasticsearch.ElasticsearchClient;
  2. import co.elastic.clients.json.jackson.JacksonJsonpMapper;
  3. import co.elastic.clients.transport.ElasticsearchTransport;
  4. import co.elastic.clients.transport.rest_client.RestClientTransport;
  5. import org.apache.http.HttpHost;
  6. import org.elasticsearch.client.RestClient;
  7. public class ElasticsearchClientExample {
  8. public static ElasticsearchClient createClient() {
  9. // 创建 Rest 客户端
  10. RestClient restClient = RestClient.builder(
  11. new HttpHost("localhost", 9200, "http")
  12. ).build();
  13. // 创建 Elasticsearch 客户端
  14. ElasticsearchTransport transport = new RestClientTransport(
  15. restClient, new JacksonJsonpMapper()
  16. );
  17. return new ElasticsearchClient(transport);
  18. }
  19. }
3. 索引文档

接下来,我们演示如何索引(插入)一个文档到 Elasticsearch 中。

  1. import co.elastic.clients.elasticsearch.core.IndexResponse;
  2. import co.elastic.clients.elasticsearch.core.IndexRequest;
  3. import co.elastic.clients.elasticsearch.core.IndexResponse.Result;
  4. import com.fasterxml.jackson.databind.ObjectMapper;
  5. public class IndexDocumentExample {
  6. public static void main(String[] args) throws Exception {
  7. ElasticsearchClient client = ElasticsearchClientExample.createClient();
  8. // 创建一个文档对象
  9. MyDocument document = new MyDocument();
  10. document.setId(1);
  11. document.setTitle("Elasticsearch Java Client Example");
  12. document.setContent("This is an example of using the Elasticsearch Java client.");
  13. // 使用 ObjectMapper 将对象转换为 JSON 字符串
  14. ObjectMapper objectMapper = new ObjectMapper();
  15. String jsonString = objectMapper.writeValueAsString(document);
  16. // 创建索引请求
  17. IndexRequest<MyDocument> request = new IndexRequest.Builder<MyDocument>()
  18. .index("my_index")
  19. .id(String.valueOf(document.getId()))
  20. .document(document)
  21. .build();
  22. // 执行索引请求
  23. IndexResponse response = client.index(request);
  24. // 检查响应结果
  25. if (response.result() == Result.Created) {
  26. System.out.println("Document indexed successfully.");
  27. } else {
  28. System.out.println("Failed to index document.");
  29. }
  30. // 关闭客户端
  31. client.close();
  32. }
  33. }
  34. class MyDocument {
  35. private int id;
  36. private String title;
  37. private String content;
  38. // Getters and Setters
  39. public int getId() {
  40. return id;
  41. }
  42. public void setId(int id) {
  43. this.id = id;
  44. }
  45. public String getTitle() {
  46. return title;
  47. }
  48. public void setTitle(String title) {
  49. this.title = title;
  50. }
  51. public String getContent() {
  52. return content;
  53. }
  54. public void setContent(String content) {
  55. this.content = content;
  56. }
  57. }
4. 查询文档

接下来,我们演示如何查询 Elasticsearch 中的文档。

  1. import co.elastic.clients.elasticsearch.core.SearchRequest;
  2. import co.elastic.clients.elasticsearch.core.SearchResponse;
  3. import co.elastic.clients.elasticsearch.core.search.Hit;
  4. public class SearchDocumentExample {
  5. public static void main(String[] args) throws Exception {
  6. ElasticsearchClient client = ElasticsearchClientExample.createClient();
  7. // 创建查询请求
  8. SearchRequest request = new SearchRequest.Builder()
  9. .index("my_index")
  10. .query(q -> q.match(m -> m.field("title").query("Elasticsearch")))
  11. .build();
  12. // 执行查询请求
  13. SearchResponse<MyDocument> response = client.search(request, MyDocument.class);
  14. // 处理查询结果
  15. for (Hit<MyDocument> hit : response.hits().hits()) {
  16. MyDocument document = hit.source();
  17. System.out.println("Found document: " + document.getTitle());
  18. }
  19. // 关闭客户端
  20. client.close();
  21. }
  22. }
5. 删除文档

最后,我们演示如何删除 Elasticsearch 中的文档。

  1. import co.elastic.clients.elasticsearch.core.DeleteRequest;
  2. import co.elastic.clients.elasticsearch.core.DeleteResponse;
  3. import co.elastic.clients.elasticsearch.core.DeleteResponse.Result;
  4. public class DeleteDocumentExample {
  5. public static void main(String[] args) throws Exception {
  6. ElasticsearchClient client = ElasticsearchClientExample.createClient();
  7. // 创建删除请求
  8. DeleteRequest request = new DeleteRequest.Builder()
  9. .index("my_index")
  10. .id("1")
  11. .build();
  12. // 执行删除请求
  13. DeleteResponse response = client.delete(request);
  14. // 检查响应结果
  15. if (response.result() == Result.Deleted) {
  16. System.out.println("Document deleted successfully.");
  17. } else {
  18. System.out.println("Failed to delete document.");
  19. }
  20. // 关闭客户端
  21. client.close();
  22. }
  23. }
总结

以上代码展示了如何在 Java 中使用 ​​elasticsearch-java​​ 客户端进行基本的 CRUD 操作。你可以根据实际需求扩展这些示例,例如处理更复杂的查询、批量操作等。希望这些示例对你有所帮助!

注:本文转载自blog.csdn.net的牛肉胡辣汤的文章"https://blog.csdn.net/q7w8e9r4/article/details/145246010"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

132
搜索
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top