JAVA 集成 ElasticSearch

目录

[ElasticSearch Client](#ElasticSearch Client)

[Java REST Client](#Java REST Client)

Dependencies

Initialization

RequestOptions

测试


ElasticSearch Client

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

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


Java REST Client

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

Dependencies

XML 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>7.4.2</version>
</dependency>

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

XML 复制代码
 <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.SR3</spring-cloud.version>
        <elasticsearch.version>7.4.2</elasticsearch.version>
 </properties>

Initialization

  • 给容器中注入一个 RestHighLevelClient
java 复制代码
@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 主要用于:

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

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

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

java 复制代码
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();
}

测试

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

java 复制代码
    @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;
    }

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

java 复制代码
    @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());
        }
    }
相关推荐
cliffordl4 分钟前
ReportLab 导出 PDF(文档创建)
开发语言·python·pdf
纪元A梦10 分钟前
华为OD机试真题——跳格子3(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·javascript·c++·python·华为od·go·华为od机试题
水w17 分钟前
【Python爬虫】简单案例介绍2
开发语言·爬虫·python
IT乐手26 分钟前
Java 实现回调监听工具类
java
IT瘾君41 分钟前
Java基础:Stream流操作
java
码里看花‌1 小时前
Reactor Core 中的 Flux:响应式数据流的核心实践
java
命运之光1 小时前
qt中解决#include “main.moc“问题
开发语言·qt
CopyLower1 小时前
Java 性能优化:从原理到实践的全面指南
java·开发语言·性能优化
ゞ 正在缓冲99%…2 小时前
leetcode14.最长公共前缀
java·算法·leetcode
七七知享2 小时前
Python深度学习实现验证码识别全攻略
开发语言·python·深度学习·程序人生·程序员·开发·验证码