Springboot整合ElasticSearch

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: Springboot整合ElasticSearch

文章目录

介绍

ElasticSearch环境搭建

拉取elasticsearch镜像

启动单个节点的

为ElasticSearch创建docker网络

启动ElasticSearch

初次启动生成密码重置

从docker镜像容器中复制安全证书到本地机器

连接测试

设置虚拟机参数

postman测试

创建索引

查看所有的索引

查看单个索引

删除索引

添加数据

查询所有的文档

springboot整合data-elasticsearch

依赖

yml配置

config配置类

dao层

服务类

服务实现类

controller类

介绍

很容易理解,search名字,顾名思义就是搜索的意思,搜索的场景很多,我们在填写表单的时候搜索地图地点,购买商品的时候筛选商品等。这种匹配需要模糊匹配,根据权重进行匹配达到我们搜索的目的,传统的访问关系型数据库没法满足,于是出现了新的技术ElasticSearch。


ElasticSearch环境搭建

环境搭建的话,我们还是在docker中进行安装。

076c815a0a654436aebcbd37d57e19fe.png

拉取elasticsearch镜像

docker pull docker.elastic.co/elasticsearch/elasticsearch:8.4.1

e6303cedc5724fc08e3c189ffb834b84.png

启动单个节点的

为ElasticSearch创建docker网络

docker network create elastic

## bddc04060de42a369112000bec26954c1404c1c163af163620eb949af5f254e9

启动ElasticSearch

-e “discovery.type=single-node”

docker run --name elasticsearch --net elastic -p 9200:9200 -p 9300:9300 -it  -e "discovery.type=single-node" docker.elastic.co/elasticsearch/elasticsearch:8.4.1

初次启动生成密码重置

-u表示需要修改的用户名

-i 表示交互式,可以自己指定密码,默认的是系统自动分配。

docker exec -it elasticsearch /usr/share/elasticsearch/bin/elasticsearch-reset-password -u -i

28c0a62c244d4cd68d3dba32a5932a0d.png

改成功之后,启动成功,可以浏览器端进行访问,输入用户名和密码

592597344aa94b0c84bfce678c56892b.png

docker镜像容器中复制安全证书到本地机器

docker cp elasticsearch:/usr/share/elasticsearch/config/certs/http_ca.crt .

连接测试

curl --cacert http_ca.crt -u elastic https://localhost:9200

设置虚拟机参数

docker run -e CLI_JAVA_OPTS="-Xms1g -Xmx1g" -e ENROLLMENT_TOKEN="<token>" --name es02 -p 9201:9200 --net elastic -it docker.elastic.co/elasticsearch/elasticsearch:docker.elastic.co/elasticsearch/elasticsearch:8.4.1


postman测试

创建索引

Put请求

http://192.168.5.130:9200/city

成功返回结果

{

   "acknowledged": true,

   "shards_acknowledged": true,

   "index": "product"

}

查看所有的索引

Get请求

http://192.168.5.130:9200/_cat/indices?v

返回所有的索引health status index   uuid                   pri rep docs.count docs.deleted store.size pri.store.size

yellow open   product txt1I7pbQG2RkSV86kyfAQ   1   1          0            0       225b           225b

yellow open   city    t6roDc9BQ2iG7Ls4Yuw-ZQ   1   1          0            0       225b           225b

查看单个索引

地址后边加上索引的名字

http://192.168.5.130:9200/product

{

   "product": {

       "aliases": {},

       "mappings": {},

       "settings": {

           "index": {

               "routing": {

                   "allocation": {

                       "include": {

                           "_tier_preference": "data_content"

                       }

                   }

               },

               "number_of_shards": "1",

               "provided_name": "product",

               "creation_date": "1662106626639",

               "number_of_replicas": "1",

               "uuid": "txt1I7pbQG2RkSV86kyfAQ",

               "version": {

                   "created": "8040199"

               }

           }

       }

   }

}

删除索引

delete 请求

http://192.168.5.130:9200/city

{

   "acknowledged": true

}

删除再次查看会

{

   "error": {

       "root_cause": [

           {

               "type": "index_not_found_exception",

               "reason": "no such index [city]",

               "resource.type": "index_or_alias",

               "resource.id": "city",

               "index_uuid": "_na_",

               "index": "city"

           }

       ],

       "type": "index_not_found_exception",

       "reason": "no such index [city]",

       "resource.type": "index_or_alias",

       "resource.id": "city",

       "index_uuid": "_na_",

       "index": "city"

   },

   "status": 404

}

添加数据

post请求

http://192.168.5.130:9200/product/_doc

body中存放json

{

 "title": "联想拯救者",

 "category": "电脑",

 "desc": "拯救者带你起飞",

 "price": 8999.0

}

返回结果:

{

   "_index": "product",

   "_id": "DcVT_YIBztDygxIIGOjO",

   "_version": 1,

   "result": "created",

   "_shards": {

       "total": 2,

       "successful": 1,

       "failed": 0

   },

   "_seq_no": 0,

   "_primary_term": 1

}

查询所有的文档

Get请求:http://192.168.5.130:9200/product/_search

输入参数:

{

"query":{

 "match_all":{}

}

}

{

   "took": 7,

   "timed_out": false,

   "_shards": {

       "total": 1,

       "successful": 1,

       "skipped": 0,

       "failed": 0

   },

   "hits": {

       "total": {

           "value": 2,

           "relation": "eq"

       },

       "max_score": 1,

       "hits": [

           {

               "_index": "product",

               "_id": "DcVT_YIBztDygxIIGOjO",

               "_score": 1,

               "_source": {

                   "title": "联想拯救者",

                   "category": "电脑",

                   "desc": "拯救者带你起飞",

                   "price": 8999

               }

           },

           {

               "_index": "product",

               "_id": "DsVV_YIBztDygxIIleg1",

               "_score": 1,

               "_source": {

                   "title": "DELL",

                   "category": "电脑",

                   "desc": "DELL全新技术",

                   "price": 7999

               }

           }

       ]

   }

}

其他操作在这里不在讲解,详细的可以看看官网的。

springboot整合data-elasticsearch

依赖

   <!-- SpringBootElasticsearch依赖 -->

   <dependency>

     <groupId>org.springframework.boot</groupId>

     <artifactId>spring-boot-starter-data-elasticsearch</artifactId>

   </dependency>

yml配置

##配置es ip和端口

elasticsearch:

 host: 192.168.5.130

 port: 9200

config配置类

/**

* 配置类

*/

@ConfigurationProperties(prefix = "elasticsearch")

@Configuration

@Data

public class EsConfig extends AbstractElasticsearchConfiguration {

   private String host;

   private Integer port;

   @Override

   public RestHighLevelClient elasticsearchClient() {

       RestClientBuilder restClientBuilder = RestClient.builder(new HttpHost(host,port));

       RestHighLevelClient restHighLevelClient = new RestHighLevelClient(restClientBuilder);

       return restHighLevelClient;

   }

}

dao层

/**

* 持久化类

* 操作文档

*/

public interface ProductDao extends ElasticsearchRepository<Product,Long> {

}

服务类

/**

* 服务接口类

*/

public interface IProductService {

   //保存

   void saveProduct(Product product);

   //更新

   void updateProduct(Product product);

   //根据

    Product getProductById(Long id);

   //获取商品列表

    List<Product> getProductList();

   //删除商品

    void deleteProductById(Long id);

}

服务实现类

/**

* 接口服务实现类

*/

@Service

public class IProductServiceImpl implements IProductService {

   @Autowired

   ProductDao productDao;

   /**

    * 保存商品

    * @param product

    */

   @Override

   public void saveProduct(Product product) {

       productDao.save(product);

   }

   /**

    * 更新商品

    * @param product

    */

   @Override

   public void updateProduct(Product product) {

      productDao.save(product);

   }

   /**

    * 根据ID获取

    * @param id

    * @return

    */

   @Override

   public Product getProductById(Long id) {

       return productDao.findById(id).get();

   }

   /**

    * 获取商品列表

    * @return

    */

   @Override

   public List<Product> getProductList() {

       Iterable<Product> products = productDao.findAll();

       List<Product> productList = new ArrayList<>();

       for(Product product:products){

           productList.add(product);

       }

       return productList;

   }

   /**

    * 删除商品

    * @param id

    */

   @Override

   public void deleteProductById(Long id) {

        productDao.deleteById(id);

   }

}

controller类

/**

* es 控制类

*/

@RestController

public class ESController {

   @Autowired

   IProductService productService;

   @GetMapping("/welcome")

   public String test(){

       return "hello,welcome to es world!";

   }

   /**

    * 保存

    * @param product

    * @return

    */

   @PostMapping("/saveProduct")

   public String saveProduct(@RequestBody  Product product){

       productService.saveProduct(product);

       return "save success";

   }

   /**

    * 更新商品

    * @param product

    * @return

    */

   @PutMapping("/updateProduct")

   public String updateProduct(@RequestBody  Product product){

       productService.saveProduct(product);

       return "update success";

   }

   /**

    * 获取单个商品

    * @param id

    * @return

    */

   @GetMapping("/getProductById/{ProductId}")

   public Product getProductById(@PathVariable("ProductId")  Long id){

       Product product = productService.getProductById(id);

       return product;

   }

   /**

    * 获取商品列表

    * @return

    */

   @GetMapping("/getProductList")

   public List<Product> getProductList(){

       return productService.getProductList();

   }

   /**

    * 删除商品

    */

   @DeleteMapping("/deleteProductById/{productId}")

   public String  deleteProductById(@PathVariable("productId")  Long id){

       productService.deleteProductById(id);

       return "delete success";

   }

}

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
3月前
|
JSON Java 网络架构
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
这篇文章介绍了如何使用Spring Boot整合REST方式来搭建和操作Elasticsearch服务。
157 4
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
|
2月前
|
JSON Java API
springboot集成ElasticSearch使用completion实现补全功能
springboot集成ElasticSearch使用completion实现补全功能
46 1
|
3月前
|
Web App开发 JavaScript Java
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
这篇文章是关于如何使用Spring Boot整合Elasticsearch,并通过REST客户端操作Elasticsearch,实现一个简单的搜索前后端,以及如何爬取京东数据到Elasticsearch的案例教程。
247 0
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
|
3月前
|
自然语言处理 Java Maven
elasticsearch学习二:使用springboot整合TransportClient 进行搭建elasticsearch服务
这篇博客介绍了如何使用Spring Boot整合TransportClient搭建Elasticsearch服务,包括项目创建、Maven依赖、业务代码和测试示例。
146 0
elasticsearch学习二:使用springboot整合TransportClient 进行搭建elasticsearch服务
|
3月前
|
自然语言处理 搜索推荐 Java
SpringBoot 搜索引擎 海量数据 Elasticsearch-7 es上手指南 毫秒级查询 包括 版本选型、操作内容、结果截图(一)
SpringBoot 搜索引擎 海量数据 Elasticsearch-7 es上手指南 毫秒级查询 包括 版本选型、操作内容、结果截图
69 0
|
3月前
|
存储 自然语言处理 搜索推荐
SpringBoot 搜索引擎 海量数据 Elasticsearch-7 es上手指南 毫秒级查询 包括 版本选型、操作内容、结果截图(二)
SpringBoot 搜索引擎 海量数据 Elasticsearch-7 es上手指南 毫秒级查询 包括 版本选型、操作内容、结果截图(二)
47 0
|
5月前
|
网络协议 Java API
SpringBoot整合Elasticsearch-Rest-Client、测试保存、复杂检索
这篇文章介绍了如何在SpringBoot中整合Elasticsearch-Rest-Client,并提供了保存数据和进行复杂检索的测试示例。
SpringBoot整合Elasticsearch-Rest-Client、测试保存、复杂检索
|
2月前
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
60 5
|
3月前
|
存储 JSON Java
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。
这篇文章是关于Elasticsearch的学习指南,包括了解Elasticsearch、版本对应、安装运行Elasticsearch和Kibana、安装head插件和elasticsearch-ik分词器的步骤。
266 0
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。
|
4月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo