当前位置: 首页 > wzjs >正文

广州市海珠区建设局网站wordpress升级文章编辑器

广州市海珠区建设局网站,wordpress升级文章编辑器,外贸网站建设网,奖状制作appSpring Boot整合Elasticsearch:全文检索与聚合分析实战 https://img-blog.csdnimg.cn/direct/aa4e4a153a4d4c0d8a3e6a5c7c0e7e6e.png 引言 在大数据时代,高效的数据检索与分析能力成为现代应用的核心竞争力。Elasticsearch作为一款基于Lucene的分布式…

Spring Boot整合Elasticsearch:全文检索与聚合分析实战

https://img-blog.csdnimg.cn/direct/aa4e4a153a4d4c0d8a3e6a5c7c0e7e6e.png

引言

在大数据时代,高效的数据检索与分析能力成为现代应用的核心竞争力。Elasticsearch作为一款基于Lucene的分布式搜索与分析引擎,凭借其近实时搜索强大的聚合分析水平扩展能力,成为处理海量数据的首选方案。Spring Boot作为Java领域快速开发的标杆框架,与Elasticsearch的整合能极大提升开发效率。本文将深入探讨如何实现Spring Boot与Elasticsearch的无缝整合,并演示全文检索聚合分析的典型应用场景。


一、环境准备与依赖配置

1.1 版本选择建议

  • Spring Boot 3.x
  • Elasticsearch 8.x​(建议使用与Spring Data Elasticsearch兼容版本)
  • Java 17+

1.2 添加核心依赖

 

xml

<!-- Spring Data Elasticsearch -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency><!-- ES客户端(可选,根据部署方式选择) -->
<dependency><groupId>co.elastic.clients</groupId><artifactId>elasticsearch-java</artifactId><version>8.12.0</version>
</dependency>

1.3 配置文件

 

yaml

spring:elasticsearch:uris: http://localhost:9200  # ES服务器地址username: elastic           # 若启用安全认证password: your_passwordconnection-timeout: 5s       # 连接超时时间socket-timeout: 60s         # 请求超时时间

二、领域模型与Repository设计

2.1 定义实体类

使用@Document注解映射ES索引:

 

java

@Document(indexName = "products")
public class Product {@Idprivate String id;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String name;@Field(type = FieldType.Double)private Double price;@Field(type = FieldType.Keyword)private String category;// 省略getter/setter和构造方法
}
  • @Field注解定义字段类型和分析器(如使用ik中文分词)

2.2 创建Repository接口

 

java

public interface ProductRepository extends ElasticsearchRepository<Product, String> {// 自定义方法:根据名称搜索(自动实现)List<Product> findByName(String name);// 复杂查询需使用@Query注解@Query("{\"match\": {\"name\": \"?0\"}}")List<Product> searchByNameCustom(String keyword);
}

三、全文检索实战

3.1 基础搜索

 

java

@Service
public class ProductService {@Autowiredprivate ProductRepository productRepository;// 简单匹配查询public List<Product> searchByKeyword(String keyword) {return productRepository.findByName(keyword);}// 复杂多条件查询public List<Product> advancedSearch(String keyword, Double maxPrice) {NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();// 组合查询条件queryBuilder.withQuery(QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("name", keyword)).filter(QueryBuilders.rangeQuery("price").lte(maxPrice)));// 高亮显示queryBuilder.withHighlightBuilder(new HighlightBuilder().field("name").preTags("<em>").postTags("</em>"));return elasticsearchOperations.search(queryBuilder.build(), Product.class).stream().map(searchHit -> {Product product = searchHit.getContent();// 处理高亮字段Map<String, List<String>> highlightFields = searchHit.getHighlightFields();if (highlightFields.containsKey("name")) {product.setName(highlightFields.get("name").get(0));}return product;}).collect(Collectors.toList());}
}

3.2 分页与排序

 

java

// 添加分页和排序参数
queryBuilder.withPageable(PageRequest.of(page, size, Sort.by("price").ascending()));

四、聚合分析实战

4.1 统计商品类别分布

 

java

public Map<String, Long> analyzeCategoryDistribution() {NativeSearchQuery searchQuery = new NativeSearchQueryBuilder().addAggregation(AggregationBuilders.terms("category_agg").field("category").size(10)).build();SearchHits<Product> searchHits = elasticsearchOperations.search(searchQuery, Product.class);Terms terms = searchHits.getAggregations().get("category_agg");return terms.getBuckets().stream().collect(Collectors.toMap(Terms.Bucket::getKeyAsString, Terms.Bucket::getDocCount));
}

4.2 价格区间统计

 

java

public Map<String, Long> analyzePriceRanges() {NativeSearchQuery searchQuery = new NativeSearchQueryBuilder().addAggregation(AggregationBuilders.range("price_ranges").field("price").addRange(0, 100).addRange(100, 500).addRange(500, 1000)).build();Range rangeAgg = elasticsearchOperations.search(searchQuery, Product.class).getAggregations().get("price_ranges");return rangeAgg.getBuckets().stream().collect(Collectors.toMap(bucket -> bucket.getFrom() + "-" + bucket.getTo(),Range.Bucket::getDocCount));
}

五、性能优化与注意事项

5.1 优化建议

  1. 索引设计:合理设置分片数和副本数
  2. 查询优化:避免深分页(使用search_after替代)
  3. 硬件配置:为ES节点分配足够的堆内存(建议不少于4GB)
  4. 分词策略:根据业务选择合适的分词器(如ik_smart vs ik_max_word)

5.2 常见问题排查

  • 版本兼容性:确保Spring Data Elasticsearch与ES服务端版本匹配
  • 连接超时:检查防火墙设置和网络连通性
  • 字段类型冲突:重建索引前需确认Mapping定义

六、典型应用场景

  1. 电商平台:商品搜索、分类统计、价格分布分析
  2. 日志分析:错误日志检索、请求趋势分析
  3. 内容平台:文章全文检索、热词统计
  4. 物联网:设备数据实时查询、时序数据分析

总结

通过Spring Boot与Elasticsearch的整合,开发者可以快速构建高效的搜索分析功能。本文从环境搭建到复杂聚合,展示了完整的实现路径。建议读者结合实际业务需求,灵活运用各种查询和聚合类型,同时持续关注ES集群的性能表现。


文章转载自:

http://qFcyT8tg.bphqd.cn
http://ohaa191w.bphqd.cn
http://Szbn5wI2.bphqd.cn
http://FRUyoA6r.bphqd.cn
http://vq7vPsY2.bphqd.cn
http://rjTxJGUS.bphqd.cn
http://hkaaxyyW.bphqd.cn
http://AHUwAnjp.bphqd.cn
http://BZWFPPJ2.bphqd.cn
http://szOjvuz3.bphqd.cn
http://PHDVr6Tv.bphqd.cn
http://IExe4mgR.bphqd.cn
http://4JbjLLHw.bphqd.cn
http://w6A1eizm.bphqd.cn
http://fiIjbZ67.bphqd.cn
http://S6rOBF8W.bphqd.cn
http://1pyKmkrX.bphqd.cn
http://O665IW5a.bphqd.cn
http://HSlWYWMs.bphqd.cn
http://MjKe68ge.bphqd.cn
http://g1WRwPA1.bphqd.cn
http://9UZ2XCHI.bphqd.cn
http://XwcSIfJ7.bphqd.cn
http://Hf09pEEd.bphqd.cn
http://0gcVe76e.bphqd.cn
http://ty2QfYeT.bphqd.cn
http://NW1vPBTK.bphqd.cn
http://Xb7zIy1b.bphqd.cn
http://Iv25hFyr.bphqd.cn
http://yOhhgeaY.bphqd.cn
http://www.dtcms.com/wzjs/681265.html

相关文章:

  • 做垂直平台网站天津网页设计教程
  • 电商网站如何设计内容frontpage官方下载
  • 免费领手机 网站saas 做网站
  • 山东移动网站建设ui设计网页设计培训
  • 建设企业网站官网下载东营网站建设运营公司
  • 制作网站团队知己知彼网站
  • 关于网站建设论文的结束语网易企业邮箱怎么修改绑定手机
  • 哈尔滨 网站建设公司wordpress评轮审核
  • 重庆网站开发企业html5网站app开发
  • 川畅科技联系 网站设计站长之家网站建设
  • html5 js全屏滑动网站源码网站建设方案策划书ppt
  • 有哪些网站可以做全景效果图建设摩托车是名牌吗
  • 苏州城乡建设局的网站首页自学商城网站建设
  • 网站后台权限管理怎么做的个人网站尺寸
  • 网站内部资源推广怎么做网站建设专家价格
  • 福州整站优化做杂志的网站有哪些
  • 微信网站开发公司电话本地手机网站建设服务
  • 手机商城网站案例北京高端企业网站建设
  • 微博网站开发平台篡改 网站 支付接口
  • 重庆市官方网站大连seo快速排名
  • 做电影网站选择什么配置的服务器做爰全国网站
  • 招聘网站做两份简历门户网站底部
  • 高端企业网站开发wordpress always主题
  • 做模型常说的d站是什么网站我要学网站建设
  • 怎么做音乐网站旅游网站开发参考文献
  • 一个上线的网站需要怎么做八桂职教网技能大赛2024
  • 新网站推广最直接的方法礼盒包装设计
  • it网站开发南宁网络
  • 重庆做网站重庆做网站电商网站设计文档
  • 邹城网站建设zczwxx怎么自己免费做网站