项目优化要点

一、防止重复请求

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或分块读取数据库。

相关推荐
那我掉的头发算什么几秒前
【SpringBoot】一篇文章讲清楚拦截器所有知识
java·spring boot·后端·spring
he___H33 分钟前
抽象工厂模式
java·抽象工厂模式
mjhcsp1 小时前
C++ 后缀平衡树解析
android·java·c++
望舒5131 小时前
代码随想录day33,动态规划part2
java·算法·leetcode·动态规划
追随者永远是胜利者1 小时前
(LeetCode-Hot100)169. 多数元素
java·算法·leetcode·go
蜜獾云2 小时前
JAVA面试题速记-第1期-java基础
java·开发语言
百锦再2 小时前
Java中的反射机制详解:从原理到实践的全面剖析
java·开发语言·jvm·spring boot·struts·spring cloud·kafka
没有bug.的程序员2 小时前
Gradle 构建优化深度探秘:从 Java 核心到底层 Android 物理性能压榨实战指南
android·java·开发语言·分布式·缓存·gradle
攒了一袋星辰2 小时前
JVM类加载过程
运维·服务器·jvm
tianyagukechat3 小时前
rockylinux9.5 配置IP
java·网络·tcp/ip