http请求不占用并发资源的同步操作

在并发环境下,对竞态资源的同步操作,肯定是会造成多个线程的阻塞,而在一个系统中并发线程数是有限的,对一个资源的同步阻塞,势必会造成其他资源的操作请求无法进入系统。

 

如:用户的余额,操作通用用户的余额肯定是同步操作,初期的解决办法是通过加锁同步用户余额操作。

synchronized (userId) {//给用户id常量加锁
余额操作业务
}


上述代码看似是锁住的是一个用户,对其他用户不受影响,但是它的并发操作会占用servlet request的多个请求资源,而tomcat等服务器的请求资源是有限的,这样是会导致其他用户的请求被阻塞在tomcat之外。

上述request请求和业务操作其实是生产者和消费者的关系,上述处理由于生产者和消费者是在同一线程中,因此它们的处理能力是相互影响的。

那怎么才能让http request请求和业务操作不在一个线程中,防止同步操作对

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值