场景描述:
1,目前我们的系统可以简单归纳成MVC的架构模式
2,每个前端的请求过来,都会在C层开启事务,最后处理结束后,也在在C层关闭事务(实际是在C层的底层统一做了事务的开启和提交);
问题描述:
有一个接口方法,用于获取数据库中的序列号,然后+1再保存到数据库。
客户的报障是:并发情况下出现了单号重复,也就是多个线程同时取到了相同的序列号,而不是等到上一个线程将序列号+1后的值。
问题分析:
初步分析,存在两个问题:
1,方法的锁不起作用
2,序列号+1的事务提交有问题
解决方案:
1,方法增加静态锁
2,接口方法内部,启动一个子线程,用于开启一个事务,获取序列号,然后+1提交数据库,提交事务,子线程执行结束。(在子线程的t.start()后,加了t.join())
时间: 2024-10-12 00:18:11