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;
    }
}
posted @ 2021-03-09 23:39  HOsystem  阅读(237)  评论(0编辑  收藏  举报