比较Redis锁和普通锁的优劣(redis锁和普通锁)

### 比较Redis锁和普通锁的优劣

分布式锁是在分布式系统中用来处理操作的行为的一种机制,而比较Redis锁和普通锁的优劣,主要就是Redis锁本质上是一种分布式锁,它有普通锁所没有的特性,开发者可以根据自己的实际需求选择合适的锁SM技术来实现。

普通锁基于操作系统的原子操作和抢占内存实现,一般申请锁为互斥锁,速度快,但因为只能在单机上运行,当集群出现负载均衡、故障迁移等情况时,它就不再能够发挥作用了。Redis锁和普通锁的优势在于,它基于 Redis 另一个比较重要的特性,即支持分布式锁,并且 Redis 的锁可以实现多进程之间的读、写锁,而且可以实现锁的非阻塞、可重入等高级特性;而且,因为 Redis 拥有非常强的持久性,即使系统发生崩溃,重启或者网络故障等情况, Redis 锁依旧可以实现高可用,基本上不会发生死锁。

但是,也存在几个不足,比如在 Redis 故障时无法持续使用锁,并且 Redis 的锁机制虽然可靠,崩溃时可重入,但是性能上仍然不及普通锁,一来用户的时间考验比较严格,同一个锁需要竞争、释放多次才能完成;二来,因为网络不稳定,可能使用节点下线造成 Redis 锁无法释放。

相比普通锁,Redis 锁具有更可靠的可用性,特别是在分布式情况下,但性能依然不及普通锁,开发者可以根据自己实际情况,选择合适的锁策略。

// 普通锁
synchronized(lock) { // 非阻塞
// 写操作
}

// redis分布式锁
String lock = redisTemplate.opsForValue().setIfAbsent(key,value);
if (lock.equals(‘ok’) { // 非阻塞
// 写操作
redisTemplate.delete(key);
}

数据运维技术 » 比较Redis锁和普通锁的优劣(redis锁和普通锁)