关注我,升职加薪少不了你!
不知道伙伴们有没有遇到过这样的问题,保存数据的时候,同一时间内,疯狂点击保存按钮,虽然已经用了业务主键去避免保存重复数据,但有时还是会出现这样的问题?这时候,是不是有些伙伴不自觉的开始撸头发了呢?
做过分布式项目或者了解过分布式锁的同学都知道,分布式锁是可以保证接口的重复性调用的。那么,如何实现呢?具体代码如下:
JedisClusterLock jedisClusterLock = new JedisClusterLock ("import");
// 加锁处理
try {
if (jedisClusterLock.lock(1)) {
// 这里是我们的业务代码
...
}else{
throw new BusinessException("正在保存,请稍后...");
}
}finally {
jedisClusterLock.unlock();
}
完事。就这么简单,你学废了吗?
关注我,升职加薪少不了你!