欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java操作elasticsearch的案例解析

 更新時間:2019年10月29日 15:00:50   作者:❤小蝦米❤  
這篇文章主要介紹了java操作elasticsearch的案例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

這篇文章主要介紹了java操作elasticsearch的案例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

到目前為止,我們一直都是使用RESTful風格的 API操作elasticsearch服務,但是通過我們之前的學習知道,elasticsearch提供了很多語言的客戶端用于操作elasticsearch服務,例如:java、python、.net、JavaScript、PHP等。而我們此次就學習如何使用java語言來操作elasticsearch服務。在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服務。

官方推薦使用Java High Level REST Client,因為在實際使用中,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做了很詳細的使用說明,我們這篇文章主要還是翻譯官網(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.條件過濾,進然后行分組,對組內(nèi)數(shù)據(jù)求平均,然后排行查詢

//ES中查詢所有主機的監(jiān)控數(shù)據(jù)
    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中查詢所有主機的監(jiān)控數(shù)據(jù)
    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());
    }

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring Boot 結(jié)合 aop 實現(xiàn)讀寫分離

    Spring Boot 結(jié)合 aop 實現(xiàn)讀寫分離

    這篇文章主要介紹了Spring Boot 結(jié)合 aop 實現(xiàn)讀寫分離的示例,幫助大家更好的理解和使用Spring Boot框架,感興趣的朋友可以了解下
    2020-11-11
  • J2SE基礎(chǔ)之在Eclipse中運行hello world

    J2SE基礎(chǔ)之在Eclipse中運行hello world

    本文的內(nèi)容非常的簡單,跟隨世界潮流,第一個Java程序輸出“Hell World!”。希望大家能夠喜歡
    2016-05-05
  • java實現(xiàn)的順時針/逆時針打印矩陣操作示例

    java實現(xiàn)的順時針/逆時針打印矩陣操作示例

    這篇文章主要介紹了java實現(xiàn)的順時針/逆時針打印矩陣操作,涉及java基于數(shù)組的矩陣存儲、遍歷、打印輸出等相關(guān)操作技巧,需要的朋友可以參考下
    2019-12-12
  • 如何基于JavaFX開發(fā)桌面程序

    如何基于JavaFX開發(fā)桌面程序

    這篇文章主要介紹了如何基于JavaFX開發(fā)桌面程序,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • JAVA偏向鎖的原理與實戰(zhàn)

    JAVA偏向鎖的原理與實戰(zhàn)

    這篇文章主要為大家詳細介紹了JAVA偏向鎖的原理與實戰(zhàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對數(shù)據(jù)庫密碼加密的方法

    SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對數(shù)據(jù)庫

    這篇文章主要介紹了SpringBoot中使用com.alibaba.druid.filter.config.ConfigTools對數(shù)據(jù)庫密碼加密的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • 解決feign調(diào)用接口不穩(wěn)定的問題

    解決feign調(diào)用接口不穩(wěn)定的問題

    這篇文章主要介紹了解決feign調(diào)用接口不穩(wěn)定的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 詳解Java線程池的使用(7種創(chuàng)建方法)

    詳解Java線程池的使用(7種創(chuàng)建方法)

    這篇文章主要介紹了詳解Java線程池的使用(7種創(chuàng)建方法),線程池的創(chuàng)建?式總共包含7種,其中6種是通過Executors創(chuàng)建的,1種是通過ThreadPoolExecutor創(chuàng)建的,今天我們就來詳細說一下
    2023-03-03
  • JetBrains IntelliJ IDEA 優(yōu)化教超詳細程

    JetBrains IntelliJ IDEA 優(yōu)化教超詳細程

    這篇文章主要介紹了JetBrains IntelliJ IDEA 優(yōu)化教超詳細程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Java關(guān)于遠程調(diào)試程序教程(以Eclipse為例)

    Java關(guān)于遠程調(diào)試程序教程(以Eclipse為例)

    這篇文章主要介紹了Java關(guān)于遠程調(diào)試程序教程(以Eclipse為例),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06

最新評論