java操作elasticsearch的案例解析

作者:❤小虾米❤ 时间:2021-06-27 19:17:13 

这篇文章主要介绍了java操作elasticsearch的案例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

到目前为止,我们一直都是使用RESTful风格的 API操作elasticsearch服务,但是通过我们之前的学习知道,elasticsearch提供了很多语言的客户端用于操作elasticsearch服务,例如:java、python、.net、JavaScript、PHP等。而我们此次就学习如何使用java语言来操作elasticsearch服务。在elasticsearch的官网上提供了两种java语言的API,一种是Java Transport Client,一种是Java REST Client。

而Java REST Client又分为Java Low Level REST Client和Java High Level REST Client,Java High Level REST Client是在Java Low Level REST Client的基础上做了封装,使其以更加面向对象和操作更加便利的方式调用elasticsearch服务。

官方推荐使用Java High Level REST Client,因为在实际使用中,Java Transport Client在大并发的情况下会出现连接不稳定的情况。

那接下来我们就来看看elasticsearch提供的Java High Level REST Client(以下简称高级REST客户端)的一些基础的操作,跟多的操作大家自行阅读elasticsearch的官方文档:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/current/java-rest-high.html在官网上已经对高级REST客户端的各种API做了很详细的使用说明,我们这篇文章主要还是翻译官网上的内容,先让大家以更友好的中文文档方式入门,等大家熟悉了这些API之后在查阅官网。

1.基本过滤查询


long start = System.currentTimeMillis();
long end = start - 4 * 60 * 60 * 1000;
RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("timestamp").from(end,true).to(start,true);
QueryBuilder s=QueryBuilders.boolQuery().must(rangeQueryBuilder);
QueryBuilder qb=new MatchAllQueryBuilder();
SearchResponse response= elasticsearchTemplate.getClient().prepareSearch("monitoring-cpu").setTypes("cloud-cpu").setQuery(s).setFrom(0)
.setSize(100).get();
SearchHits searchHits = response.getHits();
for(SearchHit hit:searchHits.getHits()){
System.out.println(hit.getSourceAsString());
}

2.条件过滤,进然后行分组,对组内数据求平均,然后排行查询


//ES中查询所有主机的监控数据
   BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();

uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", uuidStr));

//暂定向前推一天,计算平均
   long end = System.currentTimeMillis();
   long start = end - 24 * 60 * 60 * 1000;
   RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("timestamp").from(start,true).to(end,true);
   QueryBuilder timeFilter = QueryBuilders.boolQuery().must(rangeQueryBuilder);

//开始cputop查询
   //分组字段是id,排序由多个字段排序组成
   TermsAggregationBuilder orderCpu = AggregationBuilders.terms("group-uuid").field("uuid.keyword").order(Terms.Order.compound(
       Terms.Order.aggregation("avg-cpuuse", true)
   ));

//求和字段1
   AvgAggregationBuilder avgCpu = AggregationBuilders.avg("avg-cpuuse").field("usage_idle");

orderCpu.subAggregation(avgCpu);//添加到分组聚合请求中
   orderCpu.size(10);//top10限制

FilterAggregationBuilder cpuAggregationBuilder = AggregationBuilders.filter("uuidFilter", uuidsBoolQuery)
       .subAggregation(AggregationBuilders.filter("timeFilter",timeFilter).subAggregation(orderCpu));

SearchResponse response = elasticsearchTemplate.getClient().prepareSearch("monitoring-cpu").setTypes("cloud-cpu")
       .addAggregation(cpuAggregationBuilder)
       .get();

InternalFilter uuidFilterRe = response.getAggregations().get("uuidFilter");
   InternalFilter timeFilterRe = uuidFilterRe.getAggregations().get("timeFilter");

Terms tms = timeFilterRe.getAggregations().get("group-uuid");
   //遍历每一个分组的key
   for(Terms.Bucket tbb:tms.getBuckets()){
     //获取count的和
     InternalAvg avg = tbb.getAggregations().get("avg-cpuuse");
     for (Map userResource : userResources) {
       Object uuid = userResource.get("uuid");
       if (uuid != null && !"".equals(uuid.toString())){
         if (uuid.equals(tbb.getKey())){
           userResource.put("cupPercent",numberFormat.format(100.0 - avg.getValue()));
           cpuSort.add(userResource);
         }
       }
     }
   }

3.过滤聚合求平均查询


//ES中查询所有主机的监控数据
   BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();

uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", "1,2,4"));

//暂定向前推一天,计算平均
   long end = System.currentTimeMillis();
   long start = end - 24 * 60 * 60 * 1000;
   RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("timestamp").from(start,true).to(end,true);
   QueryBuilder timeFilter = QueryBuilders.boolQuery().must(rangeQueryBuilder);

//开始查询Cpu平均使用率
   FilterAggregationBuilder cpuAggregationBuilder = AggregationBuilders.filter("uuidFilter", uuidsBoolQuery)
       .subAggregation(AggregationBuilders.filter("timeFilter",timeFilter)
           .subAggregation(AggregationBuilders.avg("avgCpu").field("usage_idle")));

SearchResponse response = elasticsearchTemplate.getClient().prepareSearch("monitoring-cpu").setTypes("cloud-cpu")
       .addAggregation(cpuAggregationBuilder)
       .get();

InternalFilter uuidFilterRe = response.getAggregations().get("uuidFilter");
   InternalFilter timeFilterRe = uuidFilterRe.getAggregations().get("timeFilter");
   InternalAvg avgCpuRe = timeFilterRe.getAggregations().get("avgCpu");

String cpupercent = "0.00";
   if (!"NaN".equals(avgCpuRe.getValue() + "")){
     cpupercent = numberFormat.format(100.0 - avgCpuRe.getValue());
   }

来源:https://www.cnblogs.com/kenmeon/p/11750732.html

标签:java,操作,elasticsearch
0
投稿

猜你喜欢

  • Java微信跳一跳操作指南

    2022-07-06 11:14:36
  • 关于C# Math 处理奇进偶不进的实现代码

    2023-03-25 09:30:29
  • spring boot集成p6spy的最佳实践

    2023-04-11 23:40:36
  • WPF使用DrawingContext实现绘制刻度条

    2023-06-19 08:35:17
  • 使用Hibernate根据实体类自动生成表的方法

    2022-12-20 16:54:44
  • C#微信开发之获取接口调用凭据

    2023-10-28 07:57:54
  • spring boot RestTemplate 发送get请求的踩坑及解决

    2022-01-19 16:08:09
  • C++中auto_ptr智能指针的用法详解

    2023-05-21 02:14:05
  • Java的Struts框架简介与环境配置教程

    2023-10-29 05:23:03
  • Java使用原型模式展现每日生活应用案例详解

    2023-03-08 04:27:08
  • Android布局自定义Shap圆形ImageView可以单独设置背景与图片

    2023-02-23 15:15:35
  • Spring Boot中操作使用Redis实现详解

    2023-11-24 02:39:29
  • 总结Java对象被序列化的两种方法

    2023-05-11 09:46:52
  • javascript开发随笔3 开发iframe富文本编辑器的一点体会

    2021-09-25 09:41:28
  • 浅谈Java对象禁止使用基本类型

    2022-11-07 19:59:04
  • spring boot如何使用POI读取Excel文件

    2022-09-19 21:26:33
  • Android实现图片自动切换功能(实例代码详解)

    2022-11-10 00:30:37
  • SpringBoot整合WebService的实现示例

    2023-05-25 12:37:55
  • 解决Android调用系统分享给微信,出现分享失败,分享多文件必须为图片格式的问题

    2023-07-03 11:08:04
  • java基于包结构的请求路由实现实例分享

    2021-10-23 13:10:18
  • asp之家 软件编程 m.aspxhome.com