经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Elasticsearch » 查看文章
java操作elasticsearch的案例解析
来源:jb51  时间:2019/10/30 8:59:31  对本文有异议

这篇文章主要介绍了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.基本过滤查询

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

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

  1. //ES中查询所有主机的监控数据
  2. BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();
  3.  
  4. uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", uuidStr));
  5.  
  6. //暂定向前推一天,计算平均
  7. long end = System.currentTimeMillis();
  8. long start = end - 24 * 60 * 60 * 1000;
  9. RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("timestamp").from(start,true).to(end,true);
  10. QueryBuilder timeFilter = QueryBuilders.boolQuery().must(rangeQueryBuilder);
  11.  
  12. //开始cputop查询
  13. //分组字段是id,排序由多个字段排序组成
  14. TermsAggregationBuilder orderCpu = AggregationBuilders.terms("group-uuid").field("uuid.keyword").order(Terms.Order.compound(
  15. Terms.Order.aggregation("avg-cpuuse", true)
  16. ));
  17.  
  18. //求和字段1
  19. AvgAggregationBuilder avgCpu = AggregationBuilders.avg("avg-cpuuse").field("usage_idle");
  20.  
  21. orderCpu.subAggregation(avgCpu);//添加到分组聚合请求中
  22. orderCpu.size(10);//top10限制
  23.  
  24. FilterAggregationBuilder cpuAggregationBuilder = AggregationBuilders.filter("uuidFilter", uuidsBoolQuery)
  25. .subAggregation(AggregationBuilders.filter("timeFilter",timeFilter).subAggregation(orderCpu));
  26.  
  27. SearchResponse response = elasticsearchTemplate.getClient().prepareSearch("monitoring-cpu").setTypes("cloud-cpu")
  28. .addAggregation(cpuAggregationBuilder)
  29. .get();
  30.  
  31. InternalFilter uuidFilterRe = response.getAggregations().get("uuidFilter");
  32. InternalFilter timeFilterRe = uuidFilterRe.getAggregations().get("timeFilter");
  33.  
  34. Terms tms = timeFilterRe.getAggregations().get("group-uuid");
  35. //遍历每一个分组的key
  36. for(Terms.Bucket tbb:tms.getBuckets()){
  37. //获取count的和
  38. InternalAvg avg = tbb.getAggregations().get("avg-cpuuse");
  39. for (Map userResource : userResources) {
  40. Object uuid = userResource.get("uuid");
  41. if (uuid != null && !"".equals(uuid.toString())){
  42. if (uuid.equals(tbb.getKey())){
  43. userResource.put("cupPercent",numberFormat.format(100.0 - avg.getValue()));
  44. cpuSort.add(userResource);
  45. }
  46. }
  47. }
  48. }

3.过滤聚合求平均查询

  1. //ES中查询所有主机的监控数据
  2. BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();
  3.  
  4. uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", "1,2,4"));
  5.  
  6. //暂定向前推一天,计算平均
  7. long end = System.currentTimeMillis();
  8. long start = end - 24 * 60 * 60 * 1000;
  9. RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("timestamp").from(start,true).to(end,true);
  10. QueryBuilder timeFilter = QueryBuilders.boolQuery().must(rangeQueryBuilder);
  11.  
  12. //开始查询Cpu平均使用率
  13. FilterAggregationBuilder cpuAggregationBuilder = AggregationBuilders.filter("uuidFilter", uuidsBoolQuery)
  14. .subAggregation(AggregationBuilders.filter("timeFilter",timeFilter)
  15. .subAggregation(AggregationBuilders.avg("avgCpu").field("usage_idle")));
  16.  
  17.  
  18. SearchResponse response = elasticsearchTemplate.getClient().prepareSearch("monitoring-cpu").setTypes("cloud-cpu")
  19. .addAggregation(cpuAggregationBuilder)
  20. .get();
  21.  
  22. InternalFilter uuidFilterRe = response.getAggregations().get("uuidFilter");
  23. InternalFilter timeFilterRe = uuidFilterRe.getAggregations().get("timeFilter");
  24. InternalAvg avgCpuRe = timeFilterRe.getAggregations().get("avgCpu");
  25.  
  26. String cpupercent = "0.00";
  27. if (!"NaN".equals(avgCpuRe.getValue() + "")){
  28. cpupercent = numberFormat.format(100.0 - avgCpuRe.getValue());
  29. }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号