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


猜你喜欢
- 1.首先,八种基本数据类型分别是:int、short、float、double、long、boolean、byte、char; &
- 一、使用无参构造方法创建二、使用静态工厂创建三、使用实例工厂创建来源:https://www.cnblogs.com/jock766/p/1
- Swing中的常用按钮在Swing中,常见的按钮组件有JButton,JCheckBox,JRadioButton等,它们都是抽象类Abst
- 上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMa
- 问题在Android开发中,遇到一个问题,是ListView嵌套GridView,需要点击整个ListView的Item进行跳转。但是在点击
- 一、泛型的基本概念java与c#一样,都存在泛型的概念,及类型的参数化。java中的泛型是在jdk5.0后出现的,但是java中的泛型与C#
- 一、Java把这些不同来源和目标的数据都统一抽象为数据流。Java语言的输入输出功能是十分强大而灵活的。在Java类库中,IO部分的内容是很
- 本文为大家分享了java微信公众号企业付款的开发代码,供大家参考,具体内容如下详情参照微信开发者文档 企业付款文档 java代码
- Random random = new Random((int)(DateTime.Now.Ticks)); &nbs
- 前言Flutter 的画笔类 Paint 提供了很多图形绘制的配置属性,来供我们绘制更丰富多彩的图形。前面几篇我们介绍了 shader 属性
- 本文实例讲述了Android编程调用Camera和相册功能。分享给大家供大家参考,具体如下:xml:<LinearLayout xml
- 目的了解ReentrantLock获取锁、释放锁的流程代码package com.company.aqs;import java.util.
- 本文实例为大家分享了WebView实现文件下载功能的具体代码,供大家参考,具体内容如下本节引言本节给大家介绍的是WebView下载文件的知识
- 1、什么是AOPAOP是Aspect Oriented Programming的缩写,意思是面向方面编程,AOP实际是GoF设计模式的延续。
- 为什么需要UI自动化测试?我有一个观点,对于重复的工作,那么程序都是可以代替的,我想这是作为一个程序员的一个基本素养(能偷懒的绝不干活)。U
- 在.Net下DateTime.Ticks获得的是个long型的时间整数,具体表示是至0001 年 1 月 1 日午夜 12:00:00 以来
- 前言现在大部分App底部都有一个菜单,实现这个功能也有好多办法:- TabHost+Fragment - RadioGroup+Fragme
- 前面讲解了MediaPlayer播放网络音频,主要介绍了MediaPlayer关于网络音频的缓冲和进度条控制的方法,本文再来讲解一下Medi
- 题目:求1+2!+3!+...+20!的和程序分析:此程序只是把累加变成了累乘。程序设计:public class Ex21 {  
- 目录前言步入正题类的加载过程:1.加载2.验证3.准备4.解析5.初始化类加载器源码总结前言学生时代应抱着问题去学习一门语言,例如:在学习j