使用redis解决并发操作问题

来源:互联网 发布:后台数据集 js调用 编辑:程序博客网 时间:2024/06/05 21:56

在日常的开发中,有时我们会遇到这样的场景:多个人对同一个数据进行修改操作,导致并发问题发生。这个问题可以通过悲观锁来解决,但是悲观锁也是有限制的,在某些场景中是不适应的,因为和数据的耦合度太高了,可能会影响到其他业务的操作。而使用redis来解决这一问题是很好的选择。

原理介绍

redis的存储指令中有一个setnx方法,这个方法有一个特性,就是当键不存在的时候,会将这条数据插入,并且返回1,如果这个键已经存在了,那么就不会插入这条数据,并且返回0。

这里写图片描述

功能实现

明白了这个实现的原理之后,要实现这个功能就很简单了。

  1. 在事务开启的时候,我们就去redis中setnx一条数据,这条数据的键要和你当前操作的数据有关,这样就只会锁定一条数据,而不影响其他数据的业务,例如:做订单审核的时候,将订单号+业务简写作为键。
  2. 判断上面插入操作的返回值,如果返回1,就继续执行,如果返回0,直接return.
  3. 在事务结束之后,将redis中的这条数据删除。直接使用del(String key)就可以了。

具体实现可以参考:注解的方式实现redis分布式锁
使用zookeeper实现分布式锁的示例:zookeeper实现分布式锁

原创粉丝点击