当前位置: 首页 > news >正文

springboot中使用ElasticSearch

引入依赖

修改我们的pom.xml,加入spring-boot-starter-data-elasticsearch

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

编写配置文件

由于ElasticSearch从7.x版本开始淡化TransportClient甚至于在8.x版本中遗弃,所以spring data elasticsearch推荐我们使用rest客户端RestHingLevelClient(端口号使用9200)以及接口ElasticSearchRespositoy。

  • RestHighLevelClient 更强大,更灵活,但是不能友好的操作对象
  • ElasticSearchRepository 对象操作友好
    首先我们编写配置文件如下
@Configuration
public class ElasticSearchRestClientConfig extends AbstractElasticsearchConfiguration{@Override@Beanpublic RestHighLevelClient elasticsearchClient() {final ClientConfiguration clientConfiguration = ClientConfiguration.builder().connectedTo("192.168.8.101:9200").build();return RestClients.create(clientConfiguration).rest();}}

RestHighLevelClient方式

有了上面的rest client,我们就可以在其他的地方注入该客户端对ElasticSearch进行操作。我们新建一个测试文件,使用客户端对ElasticSearch进行基本的操作

  1. 注入RestClient
/*** ElasticSearch Rest client操作** RestHighLevelClient 更强大,更灵活,但是不能友好的操作对象* ElasticSearchRepository 对象操作友好** 我们使用rest client 主要测试文档的操作**/
@SpringBootTest
public class TestRestClient {// 复杂查询使用:比如高亮查询@Autowiredprivate RestHighLevelClient restHighLevelClient;
}
  1. 插入一条文档
/*** 新增一条文档*/
@Test
public void testAdd() throws IOException {/*** 向ES中的索引christy下的type类型中添加一天文档*/IndexRequest indexRequest = new IndexRequest("christy","user","11");indexRequest.source("{\"name\":\"齐天大圣孙悟空\",\"age\":685,\"bir\":\"1685-01-01\",\"introduce\":\"花果山水帘洞美猴王齐天大圣孙悟空是也!\"," +"\"address\":\"花果山\"}", XContentType.JSON);IndexResponse indexResponse = restHighLevelClient.index(indexRequest, RequestOptions.DEFAULT);System.out.println(indexResponse.status());
}

我们可以看到文档插入成功,我们去kibana中查询该条文档
在这里插入图片描述
3. 删除一条文档

/*** 删除一条文档*/
@Test
public void deleteDoc() throws IOException {// 我们把特朗普删除了DeleteRequest deleteRequest = new DeleteRequest("christy","user","rYBNG3kBRz-Sn-2f3ViU");DeleteResponse deleteResponse = restHighLevelClient.delete(deleteRequest, RequestOptions.DEFAULT);System.out.println(deleteResponse.status());}
}
  1. 更新一条文档
/*** 更新一条文档*/
@Test
public void updateDoc() throws IOException {UpdateRequest updateRequest = new UpdateRequest("christy","user","p4AtG3kBRz-Sn-2fMFjj");updateRequest.doc("{\"name\":\"调皮捣蛋的hardy\"}",XContentType.JSON);UpdateResponse updateResponse = restHighLevelClient.update(updateRequest, RequestOptions.DEFAULT);System.out.println(updateResponse.status());
}
  1. 批量更新文档
/*** 批量更新*/
@Test
public void bulkUpdate() throws IOException {BulkRequest bulkRequest = new BulkRequest();// 添加IndexRequest indexRequest = new IndexRequest("christy","user","13");indexRequest.source("{\"name\":\"天蓬元帅猪八戒\",\"age\":985,\"bir\":\"1685-01-01\",\"introduce\":\"天蓬元帅猪八戒因调戏嫦娥被贬下凡\",\"address\":\"高老庄\"}", XContentType.JSON);bulkRequest.add(indexRequest);// 删除DeleteRequest deleteRequest01 = new DeleteRequest("christy","user","pYAtG3kBRz-Sn-2fMFjj");DeleteRequest deleteRequest02 = new DeleteRequest("christy","user","uhTyGHkBExaVQsl4F9Lj");DeleteRequest deleteRequest03 = new DeleteRequest("christy","user","C8zCGHkB5KgTrUTeLyE_");bulkRequest.add(deleteRequest01);bulkRequest.add(deleteRequest02);bulkRequest.add(deleteRequest03);// 修改UpdateRequest updateRequest = new UpdateRequest("christy","user","10");updateRequest.doc("{\"name\":\"炼石补天的女娲\"}",XContentType.JSON);bulkRequest.add(updateRequest);BulkResponse bulkResponse = restHighLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT);BulkItemResponse[] items = bulkResponse.getItems();for (BulkItemResponse item : items) {System.out.println(item.status());}
}
  1. 查询文档
@Test
public void testSearch() throws IOException {//创建搜索对象SearchRequest searchRequest = new SearchRequest("christy");//搜索构建对象SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();searchSourceBuilder.query(QueryBuilders.matchAllQuery())//执行查询条件.from(0)//起始条数.size(10)//每页展示记录.postFilter(QueryBuilders.matchAllQuery()) //过滤条件.sort("age", SortOrder.DESC);//排序//创建搜索请求searchRequest.types("user").source(searchSourceBuilder);SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);System.out.println("符合条件的文档总数: "+searchResponse.getHits().getTotalHits());System.out.println("符合条件的文档最大得分: "+searchResponse.getHits().getMaxScore());SearchHit[] hits = searchResponse.getHits().getHits();for (SearchHit hit : hits) {System.out.println(hit.getSourceAsMap());}
}
http://www.lryc.cn/news/146013.html

相关文章:

  • 十二、集合(2)
  • 【网络设备】交换机的概念、工作原理、功能以及以太网帧格式
  • 研磨设计模式day11观察者模式
  • 第八周第二天学习总结 | MySQL入门及练习学习第四天
  • WPF数据转换
  • 《Go 语言第一课》课程学习笔记(十三)
  • 基于RUM高效治理网站用户体验入门-价值篇
  • Unity之Photon PUN2开发多人游戏如何实现组队功能
  • 大数据Flink简介与架构剖析并搭建基础运行环境
  • RISC-V IOPMP实际用例-Rapid-k模型在NVIDIA上的应用
  • 【UE5】给模型指定面添加自定义材质
  • mall:redis项目源码解析
  • RISC-V Linux系统kernel制作
  • 5G NR:PRACH时域资源
  • LLaMA-2的模型架构
  • 掌握Java框架之Struts,开启高效开发之旅!
  • 关于Vue.set()
  • Selenium 遇见伪元素该如何处理?
  • RPA技术介绍与应用价值
  • 产品经理,需要具备哪些能力和知识
  • 【C++】map和set
  • crawlab通过docker单节点部署简单爬虫
  • 【STM32】中断与NVIC以外部中断为例
  • 大学生网页设计制作作业实例代码 (全网最全,建议收藏) HTML+CSS+JS
  • Llama模型结构解析(源码阅读)
  • 基于XML实现SpringIoC配置
  • Kaniko在containerd中无特权快速构建并推送容器镜像
  • 分享5款不会被打入冷宫的神器软件
  • Windows如何部署Redis
  • VUE数据双向绑定原理解析