SpringBoot集成Elasticsearch实战

环境准备与依赖配置

我用的SpringBoot是2.7.x版本,对应选择Elasticsearch 7.17.x版本保持兼容。Maven配置关键依赖:

配置文件application.yml里需要设置集群信息:

这里特别注意网络连接问题,如果ES装在服务器上,记得开放9200端口防火墙。

实体类映射配置

创建商品实体类用于测试,注意@Document注解的indexName必须小写:

踩坑提醒:字段类型映射如果不显式指定,ES会自动推断,可能把日期字段识别成文本类型导致范围查询失效。

Repository层设计

继承ElasticsearchRepository接口就能获得基础CRUD能力:

注意命名规范,Spring Data会自动实现这些方法,无需编写实现类。

复杂查询构建

实际业务中经常需要组合查询,使用NativeSearchQueryBuilder更灵活:

高亮显示实现

搜索结果的匹配关键词需要高亮显示,配置高亮器:

性能调优经验

索引设置:分片数量根据数据量调整,建议每个分片大小控制在20-50GB

查询优化:避免深度分页,使用search_after替代from+size

连接池:调整RestClient的maxConnTotal参数,默认值在并发高时容易成为瓶颈

遇到的问题记录

最头疼的是版本兼容性问题。开始用的SpringBoot 3.0直接连不上ES 7.x,后来发现是客户端协议不匹配。另外ik分词器需要单独安装,记得下载与ES完全匹配的版本,否则启动时会报类加载错误。

测试时建议先插入几万条样本数据,因为小数据量下ES的优势不明显,还可能遇到分片未分配的问题。可以通过查看索引状态,确保所有分片都是active状态。

目前这套方案已经稳定运行三个月,查询响应时间从原来的秒级降到百毫秒内。下次准备尝试加入搜索词建议和纠错功能,有兴趣的可以继续关注后续更新。

相关推荐
阿狸猿33 分钟前
论微服务架构及其应用
java·微服务·架构
Java 码思客41 分钟前
【ElasticSearch从入门到架构师】第5章:ES DSL 检索语法精讲(核心重点)
大数据·elasticsearch
程序员黑豆1 小时前
Java中的字符串【AI全栈开发】
java
namexingyun1 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
终将老去的穷苦程序员2 小时前
基于SpringBoot的餐饮管理系统
java·spring boot·后端
心之伊始2 小时前
Spring AI Tool Calling 实战:让 Java Agent 调用本地 Bean 工具方法
java·spring boot·agent·spring ai·tool calling
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第110题】【并发篇】第10题:CAS 存在哪些问题?
java·开发语言·面试
瀚高PG实验室2 小时前
java中间件无法连接数据库
java·数据库·中间件·瀚高数据库
东南门吹雪2 小时前
JAVA TCP socket编程框架
java·高并发·socket·tcp·nio
xingyuzhisuan2 小时前
缓存命中率提升方案:从 30% 优化至 82% 全流程优化记录
java·开发语言·缓存·ai