springboot 整合elasticsearch 跨版本处理方式

场景

springboot 在整合elasticsearch 通常会受到elasticsearch 版本的影响,

1.一套代码可能要兼容多个elasticsearch 的情况

2.低版本的无法调用高版本一些方法(例如:delete_by_query)

实现逻辑

用高版本的去做参数封装,用restTemplate 去发送请求(草台战法)

实现代码

依赖

java 复制代码
<dependency>
    <groupId>org.elasticsearch</groupId>
    <artifactId>elasticsearch</artifactId>
    <version>5.6.14</version>
</dependency>

<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-client</artifactId>
    <version>5.6.14</version>
</dependency>

<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>6.2.4</version>
    <exclusions>
         <exclusion>
              <groupId>org.elasticsearch.client</groupId>
              <artifactId>elasticsearch-rest-client</artifactId>
         </exclusion>
    </exclusions>
</dependency>

示例代码

我们以_delete_by_query 为例

java 复制代码
@Autowired
private RestTemplate restTemplate;

private ResponseEntity<JSONObject> deleteByQuery2() {
        //构建查询体
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
        
        //构建查询条件
        RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("create_time");
        rangeQueryBuilder.lt(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
        rangeQueryBuilder.gte(LocalDateTime.now().minusDays(1).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
        searchSourceBuilder.postFilter(rangeQueryBuilder);
        
        //打印请求体
        log.debug("请求体:{}", searchSourceBuilder);

        //发送请求
        HttpHeaders httpHeaders = new HttpHeaders();
        HttpEntity httpEntity = new HttpEntity(searchSourceBuilder.toString(), httpHeaders);
        ResponseEntity<JSONObject> resp = restTemplate.postForEntity("http://127.0.0.1:9200/order_index/_delete_by_query", httpEntity, JSONObject.class);
        if (resp.getStatusCode().equals(HttpStatus.OK)) {
            JSONObject body = resp.getBody();
            log.debug(body.toString(SerializerFeature.DisableCircularReferenceDetect));
        }
        return resp;
    }

参考这个逻辑去处理部分问题(用自带的请求(searchrequest),部分功能受到版本限制)

相关推荐
月落归舟5 分钟前
深入解析Spring依赖注入 DI 的三种方式
java·后端·spring
geovindu6 分钟前
go:Condition Variable Pattern
开发语言·后端·设计模式·golang·条件变量模式
无风听海16 分钟前
UseForwardedHeaders 与 UsePathBase:深入理解 ASP.NET Core 代理感知中间件
后端·中间件·asp.net
CAE虚拟与现实30 分钟前
前后端调试常用工具大全
前端·后端·vue·react·angular
Elastic 中国社区官方博客35 分钟前
将 Logstash Pipeline 从 Azure Event Hubs 迁移到 OTel Collector Kafka Receiver
大数据·数据库·人工智能·分布式·elasticsearch·搜索引擎·kafka
倒流时光三十年36 分钟前
第1篇:你真的了解 Kafka 吗?—— 破冰篇
spring boot·分布式·kafka·linq
Elastic 中国社区官方博客38 分钟前
使用 Elasticsearch 与 Kibana 中的 PromQL 调查 Kubernetes 基础设施问题
大数据·数据库·elasticsearch·搜索引擎·信息可视化·kubernetes·全文检索
LIUAWEIO1 小时前
Unix 时间戳换算
前端·后端·unix·database
逸Y 仙X1 小时前
Elasticsearch 多级嵌套 Terms 分桶:深度优先与广度优先遍历技术选型文档
elasticsearch·深度优先·宽度优先
她说可以呀1 小时前
JWT令牌检验用户是否登录
java·spring boot·spring·java-ee·maven