zoukankan      html  css  js  c++  java
  • Springboot整合elasticsearch

    Elasticsearch-Rest-Client

    整合Elasticsearch

    pom.xml配置
    Maven Repository

        <properties>
            <elasticsearch.version>7.4.2</elasticsearch.version>
        </properties>
        
    <!--        导入elasticsearch的rest-high-level-client-->
            <dependency>
                <groupId>org.elasticsearch.client</groupId>
                <artifactId>elasticsearch-rest-high-level-client</artifactId>
                <version>7.4.2</version>
            </dependency>
    

    ElasticSearch 配置文件

    GulimallElasticSearchConfig.java:

    package com.atguigu.gulimall.search.config;
    /**
     * 1、导入依赖 https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high-getting-started-maven.html
     * 2、编写配置,容器中注入一个RestHighLevelClient https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high-getting-started-initialization.html
     * 3、参照API https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high.html
     */
    @Configuration
    public class GulimallElasticSearchConfig {
    
        public static final RequestOptions COMMON_OPTIONS;
        static {
            RequestOptions.Builder builder = RequestOptions.DEFAULT.toBuilder();
    //        builder.addHeader("Authorization", "Bearer " + TOKEN);
    //        builder.setHttpAsyncResponseConsumerFactory(
    //                new HttpAsyncResponseConsumerFactory
    //                        .HeapBufferedResponseConsumerFactory(30 * 1024 * 1024 * 1024));
            COMMON_OPTIONS = builder.build();
        }
    
        @Bean
        public RestHighLevelClient esRestClient() {
            //官方文档:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high-getting-started-initialization.html
    //        RestHighLevelClient client = new RestHighLevelClient(
    //                RestClient.builder(
    //                        new HttpHost("192.168.188.128", 9200, "http")));
    
            RestClientBuilder builder = null;
            //public HttpHost(String hostname, int port, String scheme)
            builder = RestClient.builder(new HttpHost("192.168.188.128", 9200, "http"));
            RestHighLevelClient client = new RestHighLevelClient(builder);
            return client;
        }
    }
    

    Elasticsearch 测试

    GulimallSearchApplicationTests.java:

    package com.atguigu.gulimall.search;
    @RunWith(SpringRunner.class)
    @SpringBootTest
    public class GulimallSearchApplicationTests {
    
        @Resource
        private RestHighLevelClient client;
    
        /**
         *  https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high-search.html
         * @throws IOException
         */
        @Test
        public void searchData() throws IOException {
    
            //1、创建检索请求
            SearchRequest searchRequest = new SearchRequest();
            // 指定索引
            searchRequest.indices("bank");
            // 检索条件 DSL
            // public SearchRequest source(SearchSourceBuilder sourceBuilder)
            // SearchSourceBuilder sourceBuilder  封装条件
            SearchSourceBuilder sourceBuilder= new SearchSourceBuilder();
            searchRequest.source(sourceBuilder);
            //(1). 构建检索条件
    //        sourceBuilder.query();
    //        sourceBuilder.from();
    //        sourceBuilder.size();
    //        sourceBuilder.aggregation();
            //public SearchSourceBuilder query(QueryBuilder query)
    
            /**
             * # 搜索 address 中包含mill的所有人的年龄分布以及平均年龄,但不显示这些人的详情
             * GET bank/_search
             * {
             *   "query": {
             *     "match": {
             *       "address": "mill"
             *     }
             *   },
             *   "aggs": {
             *     "ageAgg": {
             *       "terms": {
             *         "field": "age",
             *         "size": 10
             *       }
             *     },
             *     "ageAvg":{
             *       "avg":{
             *         "field":"age"
             *       }
             *     },
             *     "balanceAvg":{
             *       "avg": {
             *         "field": "balance"
             *       }
             *     }
             *   },
             *   "size": 0
             * }
             */
            sourceBuilder.query(QueryBuilders.matchQuery("address","mill"));
    
            // (2).构建聚合条件 按照年龄的值分布进行聚合
            // public SearchSourceBuilder aggregation(AggregationBuilder aggregation)
            TermsAggregationBuilder ageAgg = AggregationBuilders.terms("ageAgg").field("age").size(10);
            sourceBuilder.aggregation(ageAgg);
    
            // (3).计算平均薪资
            TermsAggregationBuilder balanceAvg = AggregationBuilders.terms("balanceAvg").field("balance");
            sourceBuilder.aggregation(balanceAvg);
    
            System.out.println("检索条件: "+sourceBuilder.toString());
            searchRequest.source(sourceBuilder);
    
            //2、执行检索
            SearchResponse searchResponse = client.search(searchRequest, GulimallElasticSearchConfig.COMMON_OPTIONS);
    
            //3、分析结果 SearchResponse
            System.out.println(searchResponse.toString());
    //        Map map = JSON.parseObject(searchResponse.toString(), Map.class);
            //(1).获取所有查到的数据
            SearchHits hits = searchResponse.getHits();
            SearchHit[] searchHits = hits.getHits();
            for(SearchHit hit:searchHits){
                /**
                 *         "_index" : "bank",
                 *         "_type" : "account",
                 *         "_id" : "472",
                 *         "_score" : 5.4032025,
                 *         "_source" :
                 */
    //            hit.getIndex();
    //            hit.getType();
    //            hit.getIndex();
                String sourceAsString = hit.getSourceAsString();
                // public static <T> T parseObject(String text, Class<T> clazz) 将String转为Java对象
                Account account = JSON.parseObject(sourceAsString, Account.class);
                System.out.println("账号信息account: "+account);
            }
            //(2).获取检索到的分析信息
            Aggregations aggregtion = searchResponse.getAggregations();
    //        for (Aggregation aggregation : aggregtion.asList()) {
    //            System.out.println("当前聚合: "+aggregation.getName());
    //            /**
    //             * Aggregations aggregations = searchResponse.getAggregations();
    //             * Terms byCompanyAggregation = aggregations.get("by_company");
    //             * Bucket elasticBucket = byCompanyAggregation.getBucketByKey("Elastic");
    //             * Avg averageAge = elasticBucket.getAggregations().get("average_age");
    //             * double avg = averageAge.getValue();
    //             */
    //        }
            Terms ageAgg1 = aggregtion.get("ageAgg");
            for (Terms.Bucket bucket : ageAgg1.getBuckets()) {
                String keyAsString = bucket.getKeyAsString();
                System.out.println("年龄: "+keyAsString+"  ==>  "+bucket.getDocCount());
    
            }
    
            // org.elasticsearch.search.aggregations.bucket.terms.ParsedLongTerms
            // cannot be cast to
            // org.elasticsearch.search.aggregations.metrics.Avg
            // TODO 待解决
            Avg balanceAvg1 = aggregtion.get("balanceAvg");
            System.out.println("平均薪资: "+balanceAvg1.getValue());
        }
    
        /**
         *  测试存储数据到es
         *  https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.5/java-rest-high-document-index.html
         */
        @Test
        public void indexData() throws IOException {
    
            IndexRequest indexRequest = new IndexRequest("users");
            indexRequest.id("1");
    //        indexRequest.source("userName","zhangsan","age",18,"gender","男");
    
            // 方式二:
            //推荐使用该方式
            // 将对象转成json
            User user = new User();
            user.setUserName("zhangsan");
            user.setAge(18);
            user.setGender("男");
            String jsonString = JSON.toJSONString(user);
            // 要保存到es的内容
            //java.lang.IllegalArgumentException: The number of object passed must be even but was [1] 需要添加XContentType.JSON
            indexRequest.source(jsonString, XContentType.JSON);
    
            // 执行操作
            IndexResponse index = client.index(indexRequest, GulimallElasticSearchConfig.COMMON_OPTIONS);
    
            //提取有效的效应数据
            System.out.println(index);
        }
    
        @Data
        class User{
            private String userName;
            private String gender;
            private Integer age;
        }
    
        @Data
        @ToString
        //com.alibaba.fastjson.JSONException: can't create non-static inner class instance. 添加static
        static class Account{
    
                private int account_number;
                private int balance;
                private String firstname;
                private String lastname;
                private int age;
                private String gender;
                private String address;
                private String employer;
                private String email;
                private String city;
                private String state;
        }
    }
    
  • 相关阅读:
    互联网公司做智能硬件要注意什么?
    移动GPU全解读(二)
    java JDK设置环境变量
    hive load文件第一个字段为NULL
    网页版微信和微信公共号扫码登陆原理分析
    Java&amp;Xml教程(九)Java中通过XSD校验XML合法性
    47.Android 自己定义PopupWindow技巧
    ArcGIS中数据之间的转换接口IFeatureDataConverter2
    怎样衡量代码质量?
    iOS -读书笔记-网络请求
  • 原文地址:https://www.cnblogs.com/HOsystem/p/14508972.html
Copyright © 2011-2022 走看看