java操作elasticsearch的案例解析
這篇文章主要介紹了java操作elasticsearch的案例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
到目前為止,我們一直都是使用RESTful風(fēng)格的 API操作elasticsearch服務(wù),但是通過我們之前的學(xué)習(xí)知道,elasticsearch提供了很多語言的客戶端用于操作elasticsearch服務(wù),例如:java、python、.net、JavaScript、PHP等。而我們此次就學(xué)習(xí)如何使用java語言來操作elasticsearch服務(wù)。在elasticsearch的官網(wǎng)上提供了兩種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的基礎(chǔ)上做了封裝,使其以更加面向?qū)ο蠛筒僮鞲颖憷姆绞秸{(diào)用elasticsearch服務(wù)。
官方推薦使用Java High Level REST Client,因?yàn)樵趯?shí)際使用中,Java Transport Client在大并發(fā)的情況下會出現(xiàn)連接不穩(wěn)定的情況。
那接下來我們就來看看elasticsearch提供的Java High Level REST Client(以下簡稱高級REST客戶端)的一些基礎(chǔ)的操作,跟多的操作大家自行閱讀elasticsearch的官方文檔:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/current/java-rest-high.html在官網(wǎng)上已經(jīng)對高級REST客戶端的各種API做了很詳細(xì)的使用說明,我們這篇文章主要還是翻譯官網(wǎng)上的內(nèi)容,先讓大家以更友好的中文文檔方式入門,等大家熟悉了這些API之后在查閱官網(wǎng)。
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.條件過濾,進(jìn)然后行分組,對組內(nèi)數(shù)據(jù)求平均,然后排行查詢
//ES中查詢所有主機(jī)的監(jiān)控?cái)?shù)據(jù)
BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();
uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", uuidStr));
//暫定向前推一天,計(jì)算平均
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,排序由多個(gè)字段排序組成
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");
//遍歷每一個(gè)分組的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中查詢所有主機(jī)的監(jiān)控?cái)?shù)據(jù)
BoolQueryBuilder uuidsBoolQuery = QueryBuilders.boolQuery();
uuidsBoolQuery.must(QueryBuilders.matchQuery("uuid", "1,2,4"));
//暫定向前推一天,計(jì)算平均
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());
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java訂單30分鐘未支付自動取消該怎么實(shí)現(xiàn)
在開發(fā)中往往會遇到一些關(guān)于延時(shí)任務(wù)的需求,例如生成訂單30分鐘未支付,則自動取消,下面這篇文章主要給大家介紹了關(guān)于Java訂單30分鐘未支付自動取消該怎么實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2023-03-03
Spring Boot2解決idea console 控制臺輸出亂碼的問題
這篇文章主要介紹了Spring Boot2解決idea console 控制臺輸出亂碼的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
JDK-StringJoiner構(gòu)造及添加元素源碼分析
這篇文章主要為大家介紹了JDK-StringJoiner構(gòu)造及添加元素源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Java報(bào)錯(cuò):ClassCastException問題解決方法
異常是程序中的一些錯(cuò)誤,但并不是所有的錯(cuò)誤都是異常,并且錯(cuò)誤有時(shí)候是可以避免的,下面這篇文章主要給大家介紹了關(guān)于Java報(bào)錯(cuò):ClassCastException問題解決方法,需要的朋友可以參考下2024-07-07
java Socket無法完全接收返回內(nèi)容的解決方案
這篇文章主要介紹了java Socket無法完全接收返回內(nèi)容的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
Java實(shí)現(xiàn)pdf轉(zhuǎn)圖片案例
這篇文章主要介紹了Java實(shí)現(xiàn)pdf轉(zhuǎn)圖片案例,按照步驟放置代碼,一步步完成該案例,將代碼部署便可,需要的朋友可以參考下2021-06-06
SpringBoot集成Redisson實(shí)現(xiàn)延遲隊(duì)列的場景分析
這篇文章主要介紹了SpringBoot集成Redisson實(shí)現(xiàn)延遲隊(duì)列,本文通過場景分析實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
Java并發(fā)編程必備之Synchronized關(guān)鍵字深入解析
本文我們深入探索了Java中的Synchronized關(guān)鍵字,包括其互斥性和可重入性的特性,文章詳細(xì)介紹了Synchronized的三種使用方式:修飾代碼塊、修飾普通方法和修飾靜態(tài)方法,感興趣的朋友一起看看吧2025-04-04

