JAVA多线程下,获取递增的序列号

场景描述:

   1,目前我们的系统可以简单归纳成MVC的架构模式

2,每个前端的请求过来,都会在C层开启事务,最后处理结束后,也在在C层关闭事务(实际是在C层的底层统一做了事务的开启和提交);        

问题描述:

       有一个接口方法,用于获取数据库中的序列号,然后+1再保存到数据库。

客户的报障是:并发情况下出现了单号重复,也就是多个线程同时取到了相同的序列号,而不是等到上一个线程将序列号+1后的值。  

问题分析:

       初步分析,存在两个问题:

1,方法的锁不起作用

2,序列号+1的事务提交有问题

解决方案:

       1,方法增加静态锁

2,接口方法内部,启动一个子线程,用于开启一个事务,获取序列号,然后+1提交数据库,提交事务,子线程执行结束。(在子线程的t.start()后,加了t.join())

上一篇:相聚 桂林电子科技大学第三届ACM程序设计竞赛


下一篇:Hadoop生态圈-Hive快速入门篇之Hive环境搭建