前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring事务源码详解-spring原码(一)

spring事务源码详解-spring原码(一)

作者头像
用户9919783
发布2023-09-05 14:29:10
1220
发布2023-09-05 14:29:10
举报
文章被收录于专栏:后端从入门到精通

前面说过了aop源码,这里再稍微回顾一下

我们会用注解@EnableAspectJautoProxy开启aop

当我们用了proxytargetClass会强制cglib动态代理

源码里有@Import

里面会注册AnnotionAwareAspectJAutoProxyCreator

后面会在beanDefinationMap获取到所有定义的Objects循环

如果有@Aspect则注册advisor

之后在初始化的后置处理器里作比较这些advisors。

一、事务源码

Aop有加载切面通过注解加载,创建代理在createBean方法里,调用代理用自己定义的@before和@after等注解。

事务也有这三步,但是调用代理是系统定义好的,而不是开发人员自行定义。

ACID四大特性

A原子性:要么全部成功,要么全部失败

C一致性:事务的前后数据必须保证一致

I隔离性:事务之间保证互不干扰

D持久性:数据持久化

事务的传播行为

指事务的嵌套,当事务里面再嵌套一个事务,就有多个策略。

默认是required,开启新事务,融合到外部事物当中。

SUPPORTS,不开启新事务,融合到外部事务当中。

REQUIRES_NEW,开启新事务,挂起外部事务,创建新事务。

NOT_SUPPORTS,不开启新事物,挂起外部事务。

NEVER,不开启事务,抛出异常。

MANDATORY,抛出异常,融合到外部事务。

NESTED,开启新事务,融合到外部事务,外层影响内层,内层不影响外层。

(必须到另一个类调用,传播性才会生效)

用@EnableTransactionManagement,它是基于aop,但是不开启aop也可以

事务是基于importSelector

impotSelector返回的是一个字符串数组

默认用的都是PROXY,除非在注解上注定ASPECTJ

PROXY则是采用动态代理实现事务

AutoProxyRegister里有一个registerBeanDefinitions是哪里调用的呢

在invokeBeanFactoryPostProcessors里调用的,注册bean定义

如果拿到的mode是proxy

则注册一个InfrastructureAdvisorAutoProxyCreateor

Aop和事务都会调用这个方法

会根据auto_proxy_creator_bean_name判断是否已经存在了

如果下面没有,则会创建一个RootBeanDefinition,注册到bean定义中去

Int是索引判断,事务的索引和aop的索引,会优先aop的定义覆盖之前的。

走完全面的invokeBeanFactoryPostProcessors

则开始走实例化finishBeanFactoryInitialization方法

这里拿到我们所有bean的后置处理器

其中AnnotationAwareAspectAutoProxyCreator,这就是aop的bean后置处理器

这里的事务advice是内置设置的,和aop不同,aop的是自己定义

setTransactionAttributeSource是解析我们注解

这里会指定导入的配置类一个角色,用@Role指定,但这里会被后面的aop给覆盖,就是前面说的覆盖代码。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-06-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 后端从入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档