java操作elasticsearch的案例解析
這篇文章主要介紹了java操作elasticsearch的案例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
到目前為止,我們一直都是使用RESTful風(fēng)格的 API操作elasticsearch服務(wù),但是通過(guò)我們之前的學(xué)習(xí)知道,elasticsearch提供了很多語(yǔ)言的客戶(hù)端用于操作elasticsearch服務(wù),例如:java、python、.net、JavaScript、PHP等。而我們此次就學(xué)習(xí)如何使用java語(yǔ)言來(lái)操作elasticsearch服務(wù)。在elasticsearch的官網(wǎng)上提供了兩種java語(yǔ)言的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ā)的情況下會(huì)出現(xiàn)連接不穩(wěn)定的情況。
那接下來(lái)我們就來(lái)看看elasticsearch提供的Java High Level REST Client(以下簡(jiǎn)稱(chēng)高級(jí)REST客戶(hù)端)的一些基礎(chǔ)的操作,跟多的操作大家自行閱讀elasticsearch的官方文檔:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/current/java-rest-high.html在官網(wǎng)上已經(jīng)對(duì)高級(jí)REST客戶(hù)端的各種API做了很詳細(xì)的使用說(shuō)明,我們這篇文章主要還是翻譯官網(wǎng)上的內(nèi)容,先讓大家以更友好的中文文檔方式入門(mén),等大家熟悉了這些API之后在查閱官網(wǎng)。
1.基本過(guò)濾查詢(xún)
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.條件過(guò)濾,進(jìn)然后行分組,對(duì)組內(nèi)數(shù)據(jù)求平均,然后排行查詢(xún)
//ES中查詢(xún)所有主機(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); //開(kāi)始cputop查詢(xún) //分組字段是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);//添加到分組聚合請(qǐng)求中 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.過(guò)濾聚合求平均查詢(xún)
//ES中查詢(xún)所有主機(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); //開(kāi)始查詢(xún)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()); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot 結(jié)合 aop 實(shí)現(xiàn)讀寫(xiě)分離
這篇文章主要介紹了Spring Boot 結(jié)合 aop 實(shí)現(xiàn)讀寫(xiě)分離的示例,幫助大家更好的理解和使用Spring Boot框架,感興趣的朋友可以了解下2020-11-11J2SE基礎(chǔ)之在Eclipse中運(yùn)行hello world
本文的內(nèi)容非常的簡(jiǎn)單,跟隨世界潮流,第一個(gè)Java程序輸出“Hell World!”。希望大家能夠喜歡2016-05-05java實(shí)現(xiàn)的順時(shí)針/逆時(shí)針打印矩陣操作示例
這篇文章主要介紹了java實(shí)現(xiàn)的順時(shí)針/逆時(shí)針打印矩陣操作,涉及java基于數(shù)組的矩陣存儲(chǔ)、遍歷、打印輸出等相關(guān)操作技巧,需要的朋友可以參考下2019-12-12SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對(duì)數(shù)據(jù)庫(kù)
這篇文章主要介紹了SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對(duì)數(shù)據(jù)庫(kù)密碼加密的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01解決feign調(diào)用接口不穩(wěn)定的問(wèn)題
這篇文章主要介紹了解決feign調(diào)用接口不穩(wěn)定的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09詳解Java線(xiàn)程池的使用(7種創(chuàng)建方法)
這篇文章主要介紹了詳解Java線(xiàn)程池的使用(7種創(chuàng)建方法),線(xiàn)程池的創(chuàng)建?式總共包含7種,其中6種是通過(guò)Executors創(chuàng)建的,1種是通過(guò)ThreadPoolExecutor創(chuàng)建的,今天我們就來(lái)詳細(xì)說(shuō)一下2023-03-03JetBrains IntelliJ IDEA 優(yōu)化教超詳細(xì)程
這篇文章主要介紹了JetBrains IntelliJ IDEA 優(yōu)化教超詳細(xì)程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Java關(guān)于遠(yuǎn)程調(diào)試程序教程(以Eclipse為例)
這篇文章主要介紹了Java關(guān)于遠(yuǎn)程調(diào)試程序教程(以Eclipse為例),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06