JAVA 集成 ElasticSearch

目录

ElasticSearch Client

Java REST Client

Dependencies

Initialization

RequestOptions

 测试


ElasticSearch Client

9300端口 :TCP协议,性能较高,ES集群内部节点之间通过9300进行通讯。

  • Java Transport Client (7.x 已废弃)
  • Spring Data Elasticsearch

9200端口:HTTP协议,通过http请求和ES进行交互。跨语言兼容性好,易于调试。

  • Java REST Client (8.x 已废弃)
  • Java Client (active)
  • 其他HttpClient,模拟发送http请求

Java REST Client

谷粒商城 ES 7.4.2 仅支持 Java REST Client ,之后若有需要 再进行重构

Dependencies


    org.elasticsearch.client
    elasticsearch-rest-high-level-client
    7.4.2

由于spring-boot-dependencies中有默认值,为避免冲突,应手动指定版本

 
        1.8
        Greenwich.SR3
        7.4.2
 

Initialization

  • 给容器中注入一个 RestHighLevelClient 
@Configuration
public class GulimallElasticSearchConfig {
    @Value("${search.host.address}")
    private String hostName;
    @Bean
    public RestHighLevelClient esRestClient() {
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost(hostName, 9200, "http")
                )
        );
        return client;
    }
}

GulimallSearchApplicationTests中注入的RestHighLevelClient NotNull即可

RequestOptions

RequestOptions 主要用于:

  • 共享配置:在多个请求之间共享相同的配置(如认证信息、超时设置等)。

  • 简化代码:避免在每个请求中重复设置相同的参数。

  • 提高性能:通过复用配置,减少不必要的对象创建和内存开销。

private 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();
}

 测试

  • Index API

source 可以以4种方式提供,即 Json字符串,map,XContentBuilder 或 键值对

    @Autowired
    private RestHighLevelClient esRestClient;
    @Test
    public void indexApi() throws IOException {
        //索引名
        IndexRequest request = new IndexRequest("user");
        request.id("1");
        User user=new User();
        user.setName("asuka");user.setAge("18");user.setGender("女");
        String userJson= JSON.toJSONString(user);
        request.source(userJson, XContentType.JSON);
        //同步请求
        IndexResponse indexResponse = esRestClient.index(request, GulimallElasticSearchConfig.COMMON_OPTIONS);
        System.out.println(indexResponse);
    }
    @Data
    class User{
        private String name;
        private String age;
        private String gender;
    }
  • Search API

 SearchSourceBuilder:DSL根操作,如query,aggregations,from,size等 

    @Autowired
    private RestHighLevelClient esRestClient;
    
    @Test
    public void searchApi() throws IOException {
        SearchRequest searchRequest = new SearchRequest("my_bank");
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();

        searchSourceBuilder.query(QueryBuilders.matchQuery("address","mill"));
        searchSourceBuilder.size(5);
        //求平均薪资
        AggregationBuilder avgBalance= AggregationBuilders.avg("avgBalance").field("balance");
        searchSourceBuilder.aggregation(avgBalance);
        //依据年龄分组
        AggregationBuilder byAgeAggregationBuilder= AggregationBuilders.terms("by_age").field("age");
        searchSourceBuilder.aggregation(byAgeAggregationBuilder);

        searchRequest.source(searchSourceBuilder);
        SearchResponse searchResponse = esRestClient.search(searchRequest, GulimallElasticSearchConfig.COMMON_OPTIONS);
        System.out.println(searchResponse);

        SearchHits hits= searchResponse.getHits();
        for (SearchHit hit : hits.getHits()) {
            System.out.println(hit);//也可通过JSON.parseObject() 转换为 对象
        }

        //获取聚合信息
        Aggregations aggregations = searchResponse.getAggregations();
        //依据名字取出各聚合
        Avg balanceAvg = aggregations.get("avgBalance");
        System.out.println("平均薪资: " + balanceAvg.getValue());

        Terms byAgeAggregation = aggregations.get("by_age");
        for (Terms.Bucket bucket: byAgeAggregation.getBuckets()) {
            System.out.println("年龄 :" +bucket.getKey()+ " 数量:"+ bucket.getDocCount());
        }
    }
版权声明

   站内部分内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供网络资源分享服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请 联系我们 一经核实,立即删除。并对发布账号进行永久封禁处理。在为用户提供最好的产品同时,保证优秀的服务质量。


本站仅提供信息存储空间,不拥有所有权,不承担相关法律责任。

给TA打赏
共{{data.count}}人
人已打赏
大数据

【Golang学习之旅】分布式任务队列(使用 RabbitMQ / Kafka)

2025-2-25 15:20:05

大数据

动态订阅kafka mq实现(消费者组动态上下线)

2025-2-25 15:20:07

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索