Spring 框架 作为 Java 生态的核心技术,广泛应用于企业级开发。但很多开发者只会“用”Spring,而不深入其内部原理,导致无法高效排查问题 & 进行性能优化。
本文将从 Spring 核心源码剖析、性能优化策略、实战案例 三个方面,帮助你深入理解 Spring,并掌握优化技巧,让你的 Spring 应用跑得更快、更稳!
Spring 的底层架构由 IOC(控制反转)、AOP(面向切面编程)、事务管理、Bean 生命周期、事件驱动 等核心组件组成。
我们从 IOC 容器、Bean 生命周期 & 事务管理 三个关键部分进行源码解析。
Spring IOC 容器的核心是 BeanFactory 和 ApplicationContext,其初始化过程主要涉及 BeanDefinition 解析、实例化 & 依赖注入。
核心源码解析(Bean 加载过程)
@Override
public void refresh() throws BeansException {
// 1. 解析 & 加载 BeanDefinition
obtainFreshBeanFactory();
// 2. 依赖注入,完成 Bean 实例化
finishBeanFactoryInitialization(beanFactory);
// 3. 容器启动完成
finishRefresh();
}
优化建议:
Spring Bean 经过 创建、初始化、销毁 三个生命周期,涉及多个扩展点(BeanPostProcessor
、InitializingBean
等)。
核心源码解析(Bean 初始化过程)
for (BeanPostProcessor processor : getBeanPostProcessors()) {
// 1. 前置处理(@PostConstruct)
wrappedBean = processor.postProcessBeforeInitialization(wrappedBean, beanName);
}
优化建议:
Spring 事务管理基于 TransactionInterceptor,通过 动态代理(JDK / CGLIB) 实现事务切面。
核心源码解析(事务增强)
@Transactional
public void updateUser() {
// 1. 事务开启
TransactionStatus status = transactionManager.getTransaction(definition);
try {
// 2. 业务逻辑
userRepository.save(user);
// 3. 提交事务
transactionManager.commit(status);
} catch (Exception e) {
// 4. 回滚事务
transactionManager.rollback(status);
}
}
优化建议:
@Transactional(readOnly = true)
进行只读优化NESTED
模式导致死锁Spring 提供了大量的扩展点和特性,但如果不加以优化,容易导致 启动慢、内存占用高、接口响应慢。
这里总结 Spring 应用的 5 大核心优化方向。
Spring 启动时间过长,通常由 Bean 过多、依赖扫描范围过大、反射调用过多 导致。
✅ 解决方案:
@Lazy
避免无用 Bean 初始化-XX:+TieredCompilation
spring-context-indexer
预加载 BeanSpring 依赖注入默认使用 反射机制,可能导致 性能损耗。
✅ 解决方案:
@Autowired
换成 @Resource
@Primary
避免过多 @Qualifier
匹配Spring AOP 采用 JDK 动态代理 / CGLIB 代理,如果滥用会影响性能。
✅ 解决方案:
Spring 事务管理默认使用 数据库锁,可能影响并发性能。
✅ 解决方案:
@Transactional(readOnly = true)
PROPAGATION_REQUIRES_NEW
避免事务嵌套死锁batchUpdate()
减少事务提交次数Spring MVC 处理请求时,需要经过 DispatcherServlet、HandlerMapping、拦截器、视图解析 等多个步骤。
✅ 解决方案:
Cache-Control
头Jackson @JsonView
避免无用字段ThreadPoolTaskExecutor
提高异步请求处理能力优化前:
@RestController
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/user/{id}")
public User getUser(@PathVariable Long id) {
return userService.getUserById(id);
}
}
❌ 问题:
@Autowired
,导致启动时 大量 Bean 被创建优化后:
@RestController
@RequiredArgsConstructor
public class UserController {
private final UserService userService;
@GetMapping("/user/{id}")
@Cacheable(value = "user", key = "#id")
public User getUser(@PathVariable Long id) {
return userService.getUserById(id);
}
}
✅ 优化点:
@RequiredArgsConstructor
替代 @Autowired
,避免不必要的 Bean 依赖@Cacheable
缓存,减少数据库查询掌握这些优化技巧,你的 Spring 应用将更加高效稳定!欢迎点赞 & 关注!