前面说过了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给覆盖,就是前面说的覆盖代码。