现象:
两个线程,锁加在service层方法上,线程一操作某些数据提交后,线程二读取的还是线程一修改之前的数据。
问题总结:
两个线程同时触发,不管是谁先进入方法后,另一个线程阻塞,在线程一执行完后,方法解锁,线程二进入,此时,
由spring的事务管理器提交的动作可能还没有提交完。
由于mysql Innodb引擎的默认隔离级别是可重复读(
在同一个事务里,
SELECT
的结果是事务开始时时间点的状态
),
线程二事务开始的时候,线程一还没提交完成,导致读取的数据还没更新。
处理方法:
在controller层里面,调用service的地方加锁。
这样就保证了事务一在完全提交后,事务二读取的数据得到了更新。