多线程环境下会员编号重复问题。

在高并发的环境中,多个线程同时读取表中的某字段,以其结果的自增数为下一个保存结果。

结果由于数据 “读取-处理-保存”发生在不同的时间片上,导致产生脏读数据。


问题原因: 多线程环境下数据共享导致。

解决办法:

    有一个好较好的解决办法是,在db中为该数据建立独立的sequence,每次读取的时候自动获取下一个值,从而使每个线程得到的数据都是最新的。将数据值做到与线程无关。


未使用该方法原因:

    系统使用mysql数据库,只能使用新建表模拟sequence,需要通过新建函数获取值,修改量较大,放弃。


另一个思路:

在服务器中缓存该字段最新值,做比较。

在该类中建立静态变量,在每次该值被线程获取以后都与静态变量做对比,若相同则重新获取,若不同则将新值付给静态变量。但是此方法需要将该类设置为多实例模式,否则仍存在并发问题。(此处可能有问题,多实例可能仍然对共享的静态变量存在竞争)

说明:多实例适合在并发非常高是使用,消耗系统资源也多。


最终简单解决办法:

spring mvc中默认使用单例模式,使用synchronized块将 该“读取-处理-保存”的代码段做同步处理。

缺点:因为线程互斥而性能降低。若并发非常高时不建议使用。


选中理由:1 性能降低尚在可接受范围内。 2:改动量小。


转载于:https://my.oschina.net/dlam/blog/620344

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值