多线程并发已经加了锁,仍出现数据不准确问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/edc0228/article/details/80738575

这边记一次线上出现的bug,场景描述:
服务端提供了获取码的接口,这个接口有2个动作,查询码,然后将查询出的码在表中删除,可是当多个线程并发访问时,第二个线程可以查询出第一个线程已经删除的码,这就有问题了。
排查问题:
1.怀疑是mybatis缓存引起的,把缓存关掉,还是有问题;
2.参考:链接内容 这篇文章可以确定问题是关于事务的。
解决办法:
法1.去掉service里的事务;
法2.将synchronized加在controller层;
法3.在@Transactional注解里加上 isolation=Isolation.READ_COMMITTED;
法4.修改数据库的事务隔离级别。

猜你喜欢

转载自blog.csdn.net/edc0228/article/details/80738575
今日推荐