项目优化要点

一、防止重复请求

1.前端预防措施

(1)防抖机制

①适用场景:按钮快速点击(如提交订单、保存操作)。

②实现方式:通过JavaScript防抖函数限制请求频率,例如用户连续点击时仅发送最后一次请求。

(2)按钮禁用状态

①适用场景:表单提交、文件导出防止重复操作。

②实现方式:提交请求后立即禁用按钮,响应返回后重新启用。

2.后端预防措施

(1)Token令牌机制

①适用场景:关键操作(如订单提交、库存修改)。

②实现方式:

1)生成唯一Token并存储在Redis,设置过期时间(如5分钟)。

2)前端提交时携带Token,后端验证后立即删除Token。

3)若Token不存在或已过期,拒绝请求。

(2)AOP + 自定义注解

①适用场景:需要全局防重的接口(如库存扣减、支付回调)。

②实现方式:

1)定义注解@NoRepeatSubmit,标记需要防重的接口。

2)通过AOP拦截请求,生成唯一Key(如用户ID + 接口路径),存储在ConcurrentHashMap或Redis中。

3)若Key存在,拒绝请求;否则执行逻辑并存储Key。

(3)数据库唯一索引

①适用场景:关键数据表(如订单表、库存变更记录)。

②实现方式:

1)在数据库表中对关键字段(如订单号)添加唯一索引,防止重复插入。

二、防止数据内存溢出

1.代码层优化

(1)避免静态集合无限制存储

①问题场景:使用静态Map缓存数据(如static Map<String, Object> cache)。

②解决方案:改用Redis缓存框架。

(2)及时关闭资源

①问题场景:未关闭数据库连接、文件流等。

②解决方案:使用try-with-resources或手动关闭资源

2.JVM参数调优

(1)增加堆内存

①适用场景:处理大量数据时(如批量导入库存)。

②配置方式:在启动参数中设置-Xms512m -Xmx2048m(初始堆512MB,最大堆2GB)。

(2)监控内存使用

①工具推荐:使用VisualVM或JConsole监控堆内存、GC频率等指标。

②关键指标:

1)老年代使用率:持续接近100%可能内存不足。

2)Full GC频率:频繁触发(每秒多次)需优化。

3.缓存策略优化

(1)设置缓存过期时间

①适用场景:Redis缓存热数据(如商品库存)。

②配置方式:通过redisTemplate.expire("key", 10, TimeUnit.MINUTES)设置过期时间。

(2)限制缓存大小

①适用场景:本地缓存(如Caffeine)。

②配置方式:通过maximumSize(1000)限制缓存条目数。

4.分页查询与流式处理

(1)分页查询

①适用场景:大数据量查询(如销售记录列表)。

②实现方式:使用MyBatis的RowBounds或Spring Data JPA的Pageable。

(2)流式处理

①适用场景:导出大量数据(如Excel导出)。 、

②实现方式:使用Apache POI的SXSSFWorkbook或分块读取数据库。

相关推荐
mfxcyh几秒前
基于xml、注解、JavaConfig实现spring的ioc
xml·java·spring
Flittly2 分钟前
【SpringAIAlibaba新手村系列】(13)Tool Calling 函数工具调用技术
java·spring boot·spring·ai
xdscode9 分钟前
Spring 依赖注入方式全景解析
java·后端·spring
爱吃烤鸡翅的酸菜鱼19 分钟前
Java 事件发布-订阅机制全解析:从原生实现到主流中间件
java·中间件·wpf·事件·发布订阅
无限码力28 分钟前
华为OD技术面真题 - JAVA开发- spring框架 - 7
java·开发语言·华为od·华为od面试真题·华为odjava八股文·华为odjava开发题目·华为odjava开发高频题目
Lyyaoo.34 分钟前
【JAVA基础面经】JAVA中的异常
java·开发语言
一定要AK1 小时前
JVM 全体系深度解析笔记
java·jvm·笔记
coder阿龙1 小时前
基于SpringAI+Qdrant+Ollama本地模型和向量数据库开发问答和RAG检索
java·数据库·spring boot·ai·数据库开发
Gofarlic_OMS1 小时前
HyperWorks用户仿真行为分析与许可证资源分点配置
java·大数据·运维·服务器·人工智能
徒 花1 小时前
Python知识学习08
java·python·算法