Seata AT 模式的脏读是指在全局事务未提交前,被其它业务读到已提交的分支事务的数据,本质上是Seata默认的全局事务是读未提交。
@GlobalLock 注解 + select for update +Transactional可以做到,看看源码是如何实现的?
例如我执行了select * from t_order where id = 169 for update 这个sql
由于使用了GlobalLock 注解,GlobalTransactionalInterceptor就会起作用,我们看看都做了什么?
data:image/s3,"s3://crabby-images/11954/119542a159460b98e27e0bd0b32840b842ac49be" alt=""
设置全局锁标识
data:image/s3,"s3://crabby-images/a401b/a401bece9d6b0d460aabd3baf6ca292757ad22f2" alt=""
select for update使用这个SelectForUpdateExecutor
data:image/s3,"s3://crabby-images/a515b/a515b613ef49a7c521f0582bdb77c8328df8b10c" alt=""
设置锁key
data:image/s3,"s3://crabby-images/619b6/619b69df2a98449d3404431ff6941abd2c1004d6" alt=""
事务提交时
data:image/s3,"s3://crabby-images/d4ade/d4ade7fa05b7eebbffe331fc0f8bc952d60d7113" alt=""
向tc发起请求
data:image/s3,"s3://crabby-images/e97e9/e97e90efebf2bbc9f99b438dfc312b7212c53033" alt=""
网友评论