zoukankan      html  css  js  c++  java
  • es~依赖包版本对索引初始化的影响

    es依赖包我们通常指两个org.elasticsearch:elasticsearchorg.elasticsearch.client:elasticsearch-rest-high-level-client,这两个包的版本需要对应上,你的索引初始化才能生效,否则你在实体上添加的@Setting,@Mapping是不会生效的。

    版本兼容

    对于springboot2.2.6.RELEASE版本的spring-boot-starter-data-elasticsearch来说,我们选择以下两个版本的客户端,是比较兼容的

      <dependency>
          <groupId>org.elasticsearch.client</groupId>
          <artifactId>elasticsearch-rest-high-level-client</artifactId>
          <version>6.5.4</version>
      </dependency>
      <!--  elasticsearch对应兼容版本为6.8.7-->
      <dependency>
          <groupId>org.elasticsearch</groupId>
          <artifactId>elasticsearch</artifactId>
          <version>6.8.7</version>
      </dependency>
    

    实体上添加初始化索引

    • es-mapping.json内容,确定了分片数据,副本数据,分页数等
    {
      "index": {
        // 分页数
        "max_result_window": 1000000,
        // 分片数,30G一个片
        "number_of_shards": 10,
        // 副本
        "number_of_replicas": 1
      }
    }
    
    • 实体EventRecord内容
    @Document(indexName = "kc_event_logger")
    @Setting(settingPath = "mapping/es-setting.json")
    @Data
    public class EventRecord implements Serializable {
    }
    
    • 生成的索引也是没有问题的

    注意@Mapping(mappingPath = "mapping/es-mapping.json") 这个根据xml生成mapping的我测试总有问题,而且,使用上面的方法不需要你添加@Mapping了,因为索引的mapping已经根据实体字段动态生成了。

  • 相关阅读:
    元素类型
    PS
    盒模型
    文本样式
    WebStorm、IntelliJ IDEA、JetBrains、PhpStorm、RubyMine、PyCharm
    微信iOS WKWebview 网页开发适配指南
    js取url参数
    windows 80 端口占用
    前端Demo常用库文件链接
    MAC下利用Github 、hexo、 多说、百度统计 建立个人博客指南
  • 原文地址:https://www.cnblogs.com/lori/p/15648832.html
Copyright © 2011-2022 走看看