Elasticsearch 实战 - 第五讲:ES 项目实战(一):简介及环境搭建

  • Elasticsearch 实战系列文章:
  • 一:前语
  • 1、项目文档 CSDN 专栏:《Elasticsearch 入门和项目实战》
  • 2、项目GitHub 地址:
  • 3、项目结构介绍
  • 4、已实现的ES功能
  • 5、实例测试类
  • 二:项目部署
  • 1、Spring Data Elasticsearch 简介
  • 2、导入依赖
  • 3、 配置连接信息
  • 4、组件介绍
  • 5、ElasticsearchTemplate 类
  • 6、ElasticsearchRepository 类
  • 7、编写domain(实体类)


Elasticsearch 实战系列文章:

1:Elasticsearch 实战 - 第一讲:简介以及安装 2:Elasticsearch 实战 - 第二讲:kibana 安装以及ES 的概念名词 3:Elasticsearch 实战 -

第三讲:ES 基本操作、批处理 4:Elasticsearch 实战 - 第四讲:ES 高级查询 5:Elasticsearch 实战 - 第五讲:Java 集成 Spring Data Elasticsearch(一):简介及环境搭建 6:Elasticse

arch 实战 - 第六讲:ES 项目实战(二):基本操作、批处理、高级查询

一:前语

1、项目文档 CSDN 专栏:《Elasticsearch 入门和项目实战》

博客路径:

2、项目GitHub 地址:

https://github.com/17666555910/SpringBoot-Elasticsearch-Demo

3、项目结构介绍

--- com.xinghua.elasticsearchservice
    | --- common       基础依赖
       | --- dto       展示层
       | --- model     基础实体类
       | --- utils     基础工具包
       | --- service   基础业务包(通用CRUD,批量操作接口)
          | --- impl   基础业务实现层(通用CRUD,批量操作实现)
    | --- constans     常量包
    | --- controller   视图层
    | --- model        实体
    | --- service      业务层
       | --- impl      业务实现层  
    | --- utils        工具包

4、已实现的ES功能

--- IBaseService
    | --- getIndexName():               获取ES索引名称
    | --- getIndexType():               获取ES索引类型
    | --- getEntityClass():             返回泛型上的Class对象
    | --- init(List<T> entityList):     初始化数据
    | --- createEntityEsIndex():        创建索引和映射
    | --- saveOrUpdate(T entityModel):  新增或修改
    | --- delete(String id):            删除entity
    | --- deleteIndex():                删除索引
    | --- batchInsertOrUpdate(List<T> entityModelList):批量新增/更新
    
以下是高级查询相关的接口
    | --- getPageRequest(int pageNumber, int pageSize):获取PageRequest对象
    | --- searchPage(NativeSearchQueryBuilder nativeSearchQueryBuilder, int pageNumber, int pageSize):分页查询
    | --- searchPageBySort(List<SortDTO> sortDTOList, NativeSearchQueryBuilder nativeSearchQueryBuilder, int pageNumber, int pageSize):分页查询 按照指定字段排序,多个字段按照先后顺序排序
    | --- searchList(NativeSearchQueryBuilder nativeSearchQueryBuilder):查询操作
    | --- searchListBySort(List<SortDTO> sortDTOList, NativeSearchQueryBuilder nativeSearchQueryBuilder):查询操作-按照指定字段排序,多个字段按照先后顺序排序
    | --- query(NativeSearchQueryBuilder nativeSearchQueryBuilder):用于分组查询

5、实例测试类

--- BaseProductEsTest:基础功能测试类
--- ProductEsTest:各种高级查询功能测试类

二:项目部署

1、Spring Data Elasticsearch 简介

Spring Data Elasticsearch是Spring Data项目下的一个子模块。
查看 Spring Data的官网:http://projects.spring.io/spring-data/
Spring Data 的使命是给各种数据访问提供统一的编程接口,不管是关系型数据库(如MySQL),还是非关系数据库(如Redis),或者类似Elasticsearch这样的索引数据库。从而简化开发人员的代码,提高开发效率。

本文主要参考官方文档
https://docs.spring.io/spring-data/elasticsearch/docs/current/reference/html/https://spring.io/projects/spring-data-elasticsearch

2、导入依赖

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

3、 配置连接信息

#application.properties 
# 配置集群名称,名称写错会连不上服务器,默认elasticsearch 
spring.data.elasticsearch.cluster-name=elasticsearch 
# 配置集群节点 
spring.data.elasticsearch.cluster-nodes=localhost:9300

4、组件介绍

  • ElasticsearchTemplate:框架封装的用于便捷操作Elasticsearch的模板类
  • ElasticsearchRepository:框架封装的用于便捷完成常用操作的工具接口
  • NativeSearchQueryBuilder:用于生成查询条件的构建器,需要去封装各种查询条件
  • QueryBuilder:该接口表示一个查询条件,其对象可以通过QueryBuilders工具类中的方法快速生成各种条件
  • boolQuery():生成bool条件,相当于 “bool”: { }
  • matchQuery():生成match条件,相当于 “match”: { }
  • rangeQuery():生成range条件,相当于 “range”: { }
  • AbstractAggregationBuilder:用于生成分组查询的构建器,其对象通过AggregationBuilders工具类生成
  • Pageable:表示分页参数,对象通过PageRequest.of(页数, 容量)获取
  • SortBuilder:排序构建器,对象通过SortBuilders.fieldSort(字段).order(规则)获取

5、ElasticsearchTemplate 类

该模板类,封装了便捷操作Elasticsearch的模板方法,包括 索引 / 映射 / CRUD 等底层操作和高级操作,该对象用起来会略微复杂些,尤其是对于查询,还需要把查询到的结果自己封装对象。

//该对象已经由SpringBoot完成自动配置,直接注入即可
@Autowired private ElasticsearchTemplate template;

6、ElasticsearchRepository 类

该接口是框架封装的用于操作Elastsearch的高级接口,只要我们自己的写个接口去继承该接口就能直接对Elasticsearch进行CRUD操作。

/**
   *  泛型1:domain的类型 
   *  泛型2:文档主键类型 该接口直接该给Spring,底层会使用JDK代理的方式创建对象,交给容器管理
 */ 
@Repository 
public interface ProductESRepository extends ElasticsearchRepository<User, Long> { 
	// 符合Spring Data规范的高级查询方法 
}

一般情况下,ElasticsearchTemplate和ElasticsearchRepository是分工合作的,ElasticsearchRepository已经能完成绝大部分的功能,如果遇到复杂的查询则要使用ElasticsearchTemplate,如多字段分组、高亮显示等。

7、编写domain(实体类)

基类:

package com.xinghua.elasticsearchservice.common.model;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.annotation.Id;

/**
 * @Description 基础实体类
 * @Author 姚广星
 * @Date 2020/2/28 21:18
 **/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class EntityEsModel {
    @Id
    private String id;
}

业务类:

package com.xinghua.elasticsearchservice.model;

import com.xinghua.elasticsearchservice.common.model.EntityEsModel;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;

/**
 * @Description ES 实体类
 * Document:配置操作哪个索引下的哪个类型
 * Id:标记文档ID字段
 * Field:配置映射信息,如:分词器
 * @Author 姚广星
 * @Date 2020/2/24 16:13
 **/

@Data
@NoArgsConstructor
@AllArgsConstructor
@ApiModel(value = "商品ES对象")
@Document(indexName = "product", type = "product")
public class ProductEsModel extends EntityEsModel {

    /**
     * 名称
     */
    @ApiModelProperty(value = "名称")
    @Field(analyzer = "ik_max_word", searchAnalyzer = "ik_max_word", type = FieldType.Text)
    private String title;

    /**
     * 价格
     */
    @ApiModelProperty(value = "价格")
    private Double price;

    /**
     * 产地
     */
    @ApiModelProperty(value = "产地")
    @Field(analyzer = "ik_max_word", searchAnalyzer = "ik_max_word", type = FieldType.Text)
    private String origin;

    /**
     * 品牌ID
     */
    @ApiModelProperty(value = "品牌ID")
    @Field(type = FieldType.Keyword)
    private String brandId;

    /**
     * 品牌名称
     */
    @ApiModelProperty(value = "品牌名称")
    @Field(type = FieldType.Keyword)
    private String brandName;

    /**
     * 关键字
     */
    @ApiModelProperty(value = "关键字")
    @Field(analyzer = "ik_max_word", searchAnalyzer = "ik_max_word", type = FieldType.Text)
    private String keyword;

    public ProductEsModel(String id, String title, Double price, String origin, String brandId, String brandName, String keyword) {
        super(id);
        this.title = title;
        this.price = price;
        this.origin = origin;
        this.brandId = brandId;
        this.brandName = brandName;
        this.keyword = keyword;
    }

    @Override
    public String toString() {
        return "ProductEsModel{" +
                "title='" + title + '\'' +
                ", id=" + super.getId() +
                ", price=" + price +
                ", origin='" + origin + '\'' +
                ", brandId='" + brandId + '\'' +
                ", brandName='" + brandName + '\'' +
                ", keyword='" + keyword + '\'' +
                '}';
    }
}