在并发环境下,对竞态资源的同步操作,肯定是会造成多个线程的阻塞,而在一个系统中并发线程数是有限的,对一个资源的同步阻塞,势必会造成其他资源的操作请求无法进入系统。
如:用户的余额,操作通用用户的余额肯定是同步操作,初期的解决办法是通过加锁同步用户余额操作。
synchronized (userId) {//给用户id常量加锁
余额操作业务
}
上述代码看似是锁住的是一个用户,对其他用户不受影响,但是它的并发操作会占用servlet request的多个请求资源,而tomcat等服务器的请求资源是有限的,这样是会导致其他用户的请求被阻塞在tomcat之外。
上述request请求和业务操作其实是生产者和消费者的关系,上述处理由于生产者和消费者是在同一线程中,因此它们的处理能力是相互影响的。
那怎么才能让http request请求和业务操作不在一个线程中,防止同步操作对