在日常的开发中,有时我们会遇到这样的场景:多个人对同一个数据进行修改操作,导致并发问题发生。这个问题可以通过悲观锁来解决,但是悲观锁也是有限制的,在某些场景中是不适应的,因为和数据的耦合度太高了,可能会影响到其他业务的操作。而使用redis来解决这一问题是很好的选择。
原理介绍
redis的存储指令中有一个setnx方法,这个方法有一个特性,就是当键不存在的时候,会将这条数据插入,并且返回1,如果这个键已经存在了,那么就不会插入这条数据,并且返回0。
功能实现
明白了这个实现的原理之后,要实现这个功能就很简单了。
- 在事务开启的时候,我们就去redis中setnx一条数据,这条数据的键要和你当前操作的数据有关,这样就只会锁定一条数据,而不影响其他数据的业务,例如:做订单审核的时候,将订单号+业务简写作为键。
- 判断上面插入操作的返回值,如果返回1,就继续执行,如果返回0,直接return.
- 在事务结束之后,将redis中的这条数据删除。直接使用del(String key)就可以了。
具体实现可以参考:注解的方式实现redis分布式锁
使用zookeeper实现分布式锁的示例:zookeeper实现分布式锁