MySQL:事务隔离级别、事务传播行为(简单明了版本)

MySQL事务隔离级别

  1. 读未提交(Read Uncommitted)

    • 问题存在:脏读、不可重复读、幻读。
    • 描述:事务可以读取其他事务未提交的修改。可能导致数据不一致。
  2. 读已提交(Read Committed)

    • 解决:脏读。
    • 问题存在:不可重复读、幻读。
    • 描述:事务只能读取已提交的数据,但同一事务多次读取同一数据可能结果不同。
  3. 可重复读(Repeatable Read)

    • 解决:脏读、不可重复读。
    • MySQL对幻读的处理:通过MVCC(多版本并发控制)和间隙锁(Gap Locks)避免幻读。
    • 描述:确保同一事务中多次读取同一数据的结果一致(MySQL默认隔离级别)。
  4. 串行化(Serializable)

    • 解决:所有并发问题(脏读、不可重复读、幻读)。
    • 代价:通过完全锁定相关数据实现,性能最低。

事务并发问题总结

隔离级别脏读不可重复读幻读
读未提交
读已提交
可重复读(MySQL)✅*
串行化

*MySQL通过MVCC和间隙锁在可重复读级别避免幻读,但其他数据库可能不同。


事务传播行为(Spring框架)

事务传播行为定义了事务在嵌套方法调用中的边界规则:

  1. REQUIRED

    • 如果当前存在事务,则加入该事务;否则新建一个事务。
    • 场景:默认选择,适用于大多数业务逻辑。
  2. REQUIRES_NEW

    • 无论当前是否存在事务,都新建事务,并挂起当前事务(若存在)。
    • 场景:需要独立事务的操作(如日志记录,避免主事务回滚影响日志)。
  3. SUPPORTS

    • 如果当前存在事务,则加入;否则以非事务方式执行。
    • 场景:查询操作,支持事务但不需要强制。
  4. NOT_SUPPORTED

    • 以非事务方式执行,挂起当前事务(若存在)。
    • 场景:不涉及数据修改的操作,或需要绕过事务管理。
  5. MANDATORY

    • 必须存在事务,否则抛出异常。
    • 场景:强制要求方法在事务中调用(如核心业务方法)。
  6. NEVER

    • 必须在非事务环境下执行,否则抛出异常。
    • 场景:确保方法不被事务包裹(如性能敏感的非数据库操作)。
  7. NESTED

    • 如果当前存在事务,则嵌套一个子事务(通过保存点实现);否则同REQUIRED
    • 场景:部分操作需要独立回滚(如订单创建成功后记录日志,日志失败不影响订单)。

总结

  • 隔离级别:权衡数据一致性与性能,从低到高逐步解决脏读、不可重复读、幻读。
  • 传播行为:控制事务边界,解决多方法调用时事务如何协同(提交/回滚)。
  • 实际应用:MySQL默认的可重复读已满足多数场景,结合传播行为(如REQUIREDREQUIRES_NEW)可灵活管理复杂业务逻辑。
如果你是一名专业的java高级架构师,现在你在面试知识,如下是Spring和SpringMVC的面试知识体系结构图 请按照这个体系给出每个知识点的学习理解方便记忆和消化,同时给出每个知识点的高频面试的标准面试答案,结合项目经验给出解释和实战 Spring和SpringMVC面试核心知识体系 ├── 一、Spring框架基础 │ ├── 核心概念 │ │ ├── Spring是什么?有哪些核心优势?(解耦、集成、AOP等) │ │ ├── IoC(控制反转)和DI(依赖注入):概念、区别与好处? │ │ └:Spring容器:BeanFactory vs ApplicationContext区别? │ ├── 配置方式 │ │ ├── 有哪几种配置方式?(XML、注解、Java Config) │ │ ├── @Configuration + @Bean 与 @Component 的区别? │ │ └── 如何混合使用不同的配置方式? │ └── Bean管理 │ ├── Bean的作用域:singleton, prototype, request等区别? │ ├── Bean的生命周期:从创建到销毁的完整流程? │ └── 循环依赖问题:什么是循环依赖?Spring如何解决(三级缓存)? ├── 二、IoC(控制反转)与DI(依赖注入)深度解析 │ ├── 依赖注入方式 │ │ ├── 构造器注入 vs Setter注入:推荐哪种?为什么? │ │ ├── 字段注入(@Autowired)的优缺点? │ │ └── @Autowired, @Resource, @Inject 注解的区别? │ ├── 自动装配 │ │ ├── 自动装配的模式(byName, byType等)? │ │ ├── @Primary 和 @Qualifier 注解的作用与区别? │ │ └:如何解决自动装配时的歧义性? │ └── 条件化装配 │ ├── @Profile:作用?如何激活不同环境的配置? │ └── @Conditional:原理?如何自定义条件? ├── 三、AOP(面向切面编程) │ ├── AOP核心概念 │ │ ├── AOP解决了什么问题?主要应用场景?(日志、事务、安全等) │ │ ├── 连接点(Joinpoint)、切点(Pointcut)、通知(Advice)、切面(Aspect)概念? │ │ └── 织入(Weaving):编译期、类加载期、运行期织入区别? │ ├── 代理机制 │ │ ├── Spring AOP默认使用哪种代理?JDK动态代理 vs CGLIB代理区别? │ │ └── 什么情况下使用CGLIB代理? │ └── 通知类型与使用 │ ├── 5种通知类型:@Before, @After, @AfterReturning, @AfterThrowing, @Around │ ├── @Around 和其他通知的区别?如何控制目标方法执行? │ └── 如何获取方法参数、方法名等信息(JoinPoint, ProceedingJoinPoint)? ├── 四、Spring事务管理 │ ├── 事务核心接口 │ │ ├── PlatformTransactionManager:作用?常见实现类(DataSourceTransactionManager等) │ │ ├── TransactionDefinition:定义事务属性(传播行为隔离级别等) │ │ └── TransactionStatus:描述事务状态 │ ├── 声明式事务 │ │ ├── 如何开启声明式事务?(@EnableTransactionManagement) │ │ ├── @Transactional 注解可以作用在哪些地方?(类、方法)优先级? │ │ └── 事务失效的常见场景?(非public方法、自调用、异常被捕获等) │ └── 事务属性 │ ├── 传播行为(Propagation):REQUIRED, REQUIRES_NEW, NESTED等区别? │ ├── 隔离级别(Isolation):READ_UNCOMMITTED, READ_COMMITTED等与数据库关系? │ └── 回滚规则:如何设置回滚/不回滚的异常类型? ├── 五、Spring MVC核心架构 │ ├── 请求处理流程 │ │ ├── 描述一次请求的完整处理流程(DispatcherServlet -> 控制器 -> 视图)? │ │ ├── 核心组件:DispatcherServlet, HandlerMapping, HandlerAdapter, ViewResolver作用? │ │ └── 流程图的关键步骤是什么? │ ├── 控制器(Controller) │ │ ├── @Controller 和 @RestController 的区别? │ │ ├── 常用注解:@RequestMapping, @GetMapping, @PostMapping等 │ │ └── @ResponseBody 的作用?如何将返回值转为JSON(HttpMessageConverter)? │ └── 数据处理与视图解析 │ ├── 参数绑定:@RequestParam, @PathVariable, @RequestBody, @ModelAttribute区别? │ ├── 数据模型:Model, ModelMap, ModelAndView 的使用? │ └── 视图解析:InternalResourceViewResolver如何工作? ├── 六、Spring MVC高级特性 │ ├── 拦截器(Interceptor) │ │ ├── 拦截器 vs 过滤器(Filter)的区别? │ │ ├── 拦截器的三个方法:preHandle, postHandle, afterCompletion执行时机? │ │ └── 如何配置多个拦截器?执行顺序? │ ├── 统一异常处理 │ │ ├── @ControllerAdvice + @ExceptionHandler 如何实现全局异常处理? │ │ ├── HandlerExceptionResolver 接口的作用? │ │ └── @ResponseStatus 注解的使用? │ └── 文件上传与Restful API │ ├── 如何实现文件上传?(MultipartResolver) │ ├── Restful风格API的设计原则?(GET/POST/PUT/DELETE) │ └── 如何解决跨域问题?(@CrossOrigin, CorsFilter) ├── 七、Spring与第三方框架集成 │ ├── 数据访问 │ │ ├── Spring JDBC:JdbcTemplate的优势? │ │ ├── 集成MyBatis:需要哪些配置?@MapperScan作用? │ │ └── 集成JPA(Hibernate):如何配置? │ ├── 测试框架 │ │ ├── Spring TestContext Framework:@SpringBootTest, @DataJpaTest等 │ │ ├── 如何模拟MVC测试?(@WebMvcTest, MockMvc) │ │ └── 如何 mock Bean?(@MockBean) │ └── 其他集成 │ ├── 如何集成缓存?(@Cacheable, 支持Redis, Ehcache等) │ └── 如何集成任务调度?(@Scheduled, @Async) ├── 八、Spring新特性与原理进阶 │ ├── Spring Boot关联 │ │ ├── Spring Boot 和 Spring 的关系?自动配置原理? │ │ └── starter 的作用?如何自定义 starter? │ ├── 设计模式应用 │ │ ├── Spring中使用了哪些设计模式?(工厂、单例、代理、模板方法等) │ │ └── 举例说明模板方法模式在JdbcTemplate中的应用? │ └── 源码与原理 │ ├── Spring如何管理单例Bean的线程安全问题? │ ├── ApplicationContext的刷新流程(refresh()方法)大致过程? │ └── Spring事件机制(ApplicationEvent、ApplicationListener)? └── 九、常见问题与解决方案 ├── 性能与配置 │ ├── 如何优化Spring应用启动速度?(懒加载、组件扫描路径优化) │ └── 如何外部化配置?(@PropertySource, @Value, @ConfigurationProperties) ├── 开发实践 │ ├── 如何优雅地读取配置文件? │ ├── Spring中有哪些扩展点?(BeanPostProcessor, BeanFactoryPostProcessor) │ └── 如何自定义注解并使其生效? └── 疑难杂症 ├── @Transactional 和 @Async 在同一个类中调用为什么失效?(代理机制) └── 如何解决Spring应用中的内存泄漏问题?
最新发布
09-29
<think>好的,我现在需要处理用户关于Spring和SpringMVC的面试知识体系的问题。用户希望得到每个知识点的学习理解方法、高频面试答案以及结合项目经验的解释和实战。首先,我得先理清整个体系结构,确保覆盖所有提到的模块。 用户提供的结构图分为九个主要部分,每个部分下有子知识点。我需要逐一分析每个知识点,给出学习建议、标准答案和项目实例。例如,第一部分是Spring框架基础,包括核心概念、配置方式和Bean管理。对于每个子点,我需要解释其定义,常见问题,以及如何在实际项目中应用。 接下来,我需要确保回答符合用户指定的格式。每个知识点需要分为学习理解、高频面试答案和项目经验三个部分,并且最后要附上相关问题。同时,代码示例需要正确,并且相关问题必须放在末尾,格式正确。 需要注意用户可能没有提到的细节,比如如何将理论与项目经验结合。例如,在Bean的作用域中,可以举例说明在Web应用中使用prototype作用域解决多线程问题。此外,高频面试答案需要简洁明了,突出重点,比如在事务失效场景时,要提到自调用和异常被捕获的情况。 还要检查是否有遗漏的知识点,比如Spring MVC的请求处理流程,需要详细说明每个组件的作用,如DispatcherServlet如何协调HandlerMapping和ViewResolver。同时,在高级特性部分,拦截器和过滤器的区别需要明确,可能涉及执行顺序和应用场景。 另外,用户可能希望答案不仅涵盖理论,还包括实际开发中的技巧和解决方案。例如,在解决循环依赖时,Spring的三级缓存机制,需要解释其原理及如何在实际中避免此类问题。同时,对于Spring Boot的自动配置原理,可能需要结合自定义starter的例子来说明。 最后,相关问题需要围绕用户的问题生成,确保每个知识点都有对应的问题,帮助用户进一步巩固和扩展知识。例如,在Spring事务管理部分,可以提问传播行为的具体使用场景,或者隔离级别数据库的影响。 整个过程中,需要保持回答的结构清晰,语言简洁,同时符合用户严格的格式要求,避免任何格式错误导致回答无效。需要反复检查每个部分是否符合示例格式,尤其是代码块和相关问题的排版是否正确。</think>### 一、Spring框架基础 #### 学习理解 1. **核心概念**:通过解耦合设计模式理解IoC,用生活场景类比(如餐厅点餐 vs 自己做饭) 2. **配置方式**:对比XML配置(显式声明)与注解配置(隐式约定),Java Config可结合@Configuration类理解 3. **Bean管理**:生命周期可结合工厂流水线比喻(原料采购->生产->质检->出库->报废) #### 高频面试答案 **Q:Bean作用域区别?** - singleton:单例模式(Spring容器管理) - prototype:每次请求新建实例(如WebSocket连接) - request:Web应用中每次HTTP请求新建 **Q:Spring三级缓存解决循环依赖?** 1. 一级缓存:单例池(已初始化Bean) 2. 二级缓存:提前暴露的Bean对象 3. 三级缓存:Bean工厂(用于解决AOP代理) #### 项目实战 ```java // 解决prototype作用域导致的线程安全问题 @Bean @Scope("prototype") public UserService userService() { return new UserService(); } // 实际项目中通过ThreadLocal存储用户会话信息 ``` --- ### 二、IoC与DI深度解析 #### 学习理解 - **注入方式**:构造器注入(强制依赖)vs Setter注入(可选依赖) - **@Primary vs @Qualifier**:前者用于主Bean选择,后者用于精确指定Bean名称 #### 高频面试答案 **Q:@Autowired与@Resource区别?** - @Autowired:Spring专有,按类型注入 - @Resource:J2EE标准,按名称注入(默认按name查找) **Q:如何解决自动装配歧义?** ```java @Component("mysqlDB") public class MySQLDatabase implements Database {} @Autowired @Qualifier("mysqlDB") private Database database; ``` #### 项目实战 在支付模块中通过@Profile实现多环境配置: ```java @Configuration @Profile("prod") public class ProductionConfig { @Bean public PaymentService paymentService() { return new AlipayService(); } } ``` --- ### 三、AOP面向切面编程 #### 学习理解 - **代理机制**:JDK动态代理(接口) vs CGLIB(子类继承) - **通知类型**:@Around用于处理事务,@AfterThrowing用于异常统计 #### 高频面试答案 **Q:AOP典型应用场景?** 1. 日志记录(方法执行耗时) 2. 事务管理(@Around环绕通知) 3. 参数校验(@Before前置通知) **Q:CGLIB代理触发条件?** - 目标类没有实现接口 - 强制配置使用CGLIB(@EnableAspectJAutoProxy(proxyTargetClass=true)) #### 项目实战 实现接口请求日志记录: ```java @Around("execution(* com.example.service.*.*(..))") public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable { long startTime = System.currentTimeMillis(); Object result = joinPoint.proceed(); // 记录日志到ELK log.info("接口耗时:{}ms", System.currentTimeMillis() - startTime); return result; } ``` --- ### 四、Spring事务管理 #### 学习理解 - **传播行为**:REQUIRED(默认)、REQUIRES_NEW(新建事务) - **隔离级别**:读已提交(避免脏读) vs 可重复读(解决幻读) #### 高频面试答案 **Q:@Transactional失效场景?** 1. 非public方法(代理失效) 2. 同类方法调用(绕过代理) 3. 异常被捕获未抛出 **Q:事务回滚配置?** ```java @Transactional(rollbackFor = Exception.class) public void transferMoney(Account from, Account to) { // 转账逻辑 } ``` #### 项目实战 在订单模块中处理分布式事务: ```java // 使用ShardingSphere的分布式事务 @ShardingTransactionType(TransactionType.BASE) @Transactional public void createOrder(Order order) { orderRepository.save(order); inventoryService.reduceStock(order.getProductId()); } ``` --- ### 五、Spring MVC架构 #### 学习理解 - **请求流程**:DispatcherServlet(前端控制器)-> HandlerMapping(处理器映射)-> ViewResolver(视图解析) - **参数绑定**:@RequestBody(JSON反序列化) vs @RequestParam(表单数据) #### 高频面试答案 **Q:@RestController vs @Controller?** - @RestController = @Controller + @ResponseBody - 适用于前后端分离(返回JSON) vs 传统MVC(返回视图名) **Q:视图解析流程?** 1. 控制器返回"index"字符串 2. InternalResourceViewResolver添加前缀/WEB-INF/views/和后缀.jsp 3. 最终解析为/index.jsp #### 项目实战 实现文件上传功能: ```java @PostMapping("/upload") public String handleFileUpload(@RequestParam("file") MultipartFile file) { // 使用FastDFS存储文件 String fileId = fastDFSClient.upload(file); return "redirect:/file/" + fileId; } ``` --- ### 六、高级特性 #### 学习理解 - **拦截器执行顺序**:preHandle(按配置顺序)-> postHandle(倒序)-> afterCompletion(倒序) - **全局异常处理**:@ControllerAdvice统一处理业务异常 #### 高频面试答案 **Q:拦截器与过滤器区别?** - 拦截器:基于HandlerMapping(Spring MVC特有) - 过滤器:Servlet规范(处理所有请求) **Q:跨域解决方案?** 1. 注解方式:@CrossOrigin 2. 全局配置: ```java @Bean public CorsFilter corsFilter() { return new CorsWebFilter((corsConfigSource) -> { CorsConfiguration config = new CorsConfiguration(); config.setAllowCredentials(true); config.addAllowedOrigin("*"); return config; }); } ``` #### 项目实战 实现登录拦截器: ```java @Override public boolean preHandle(HttpServletRequest request...){ if(request.getSession().getAttribute("user") == null){ response.sendRedirect("/login"); return false; } return true; } ``` --- ### 七、第三方框架集成 #### 学习理解 - **MyBatis集成**:@MapperScan扫描接口,SqlSessionFactory自动配置 - **Redis缓存**:@Cacheable注解实现方法级缓存 #### 高频面试答案 **Q:JdbcTemplate优势?** - 简化JDBC操作(自动关闭资源) - 异常转换(SQLException -> DataAccessException) **Q:异步任务配置?** ```java @EnableAsync @Configuration public class AsyncConfig { @Bean public Executor asyncExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(5); return executor; } } ``` #### 项目实战 使用Spring Data JPA实现分页查询: ```java public interface UserRepository extends JpaRepository<User, Long> { Page<User> findByAgeGreaterThan(int age, Pageable pageable); } ``` --- ### 八、原理进阶 #### 学习理解 - **设计模式**:模板方法(JdbcTemplate)、策略模式(事务管理) - **事件机制**:ApplicationEventPublisher发布事件 #### 高频面试答案 **Q:Spring线程安全?** - 单例Bean:通过ThreadLocal存储用户会话信息 - prototype作用域:每次请求新建实例 **Q:refresh()方法关键步骤?** 1. 创建BeanFactory 2. 加载Bean定义 3. 实例化Bean 4. 初始化Bean #### 项目实战 自定义Spring Boot Starter: 1. 定义自动配置类 2. 在META-INF/spring.factories注册 3. 提供默认配置属性 --- ### 九、常见问题 #### 学习理解 - **性能优化**:组件扫描路径精确化,启用懒加载 - **扩展点**:BeanPostProcessor修改Bean定义 #### 高频面试答案 **Q:@Async失效原因?** - 代理机制限制:同类方法调用不经过代理 - 解决方案:通过ApplicationContext获取代理对象 **Q:内存泄漏排查?** 1. 使用MAT分析堆转储 2. 检查未关闭的数据库连接 3. 清理ThreadLocal变量 #### 项目实战 使用@Scheduled实现定时任务: ```java @Scheduled(cron = "0 0 2 * * ?") // 每天凌晨2点执行 public void dailyReportTask() { // 生成报表逻辑 } ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值