架构-轻松搞懂锁和分布式锁

本文介绍了在多线程环境下为何使用锁,以及线程锁、进程锁和分布式锁的区别。重点讲解了分布式锁的概念和特点,特别讨论了基于Redis的分布式锁实现,包括使用setnx命令加锁、del命令解锁以及设置超时时间防止死锁。文中提供了简单的伪代码示例,并推荐了其他Redis分布式锁相关文章以供深入学习。
摘要由CSDN通过智能技术生成

为什么使用锁:

多线程环境中,经常遇到多个线程访问同一个 共享资源 ,这时候作为开发者必须考虑如何维护数据一致性,这就需要某种机制来保证只有满足某个条件(获取锁成功)的线程才能访问资源,而不满足条件(获取锁失败)的线程只能等待,在下一轮竞争中来获取锁才能访问资源。

什么是分布式锁?

  1. 线程锁
    主要用来给方法、代码块加锁。当某个方法或代码使用锁,在同一时刻仅有一个线程执行该方法或该代码段。线程锁只在同一JVM中有效果,因为线程锁的实现在根本上是依靠线程之间共享内存实现的,比如Synchronized、Lock等。
  2. 进程锁
    为了控制同一操作系统中多个进程访问某个共享资源,因为进程具有独立性,各个进程无法访问其他进程的资源,因此无法通过synchronized等线程锁实现进程锁。
  3. 分布式锁
    实现不同机器对同一资源的加锁,当多个进程不在同一个系统中,用分布式锁控制多个进程对资源的访问。

分布式锁的特点

1、互斥性:任意时刻,只能有一个客户端获取锁,不能同时有两个客户端获取到锁。
2、安全性:锁只能被持有该锁的客户端删除,不能由其它客户端删除。
3、死锁:获取锁的客户端因为某些原因(如down机等)而未能释放锁,其它客户端再也无法获取到该锁。
4、容错:当部分节点(redis节点等)down机时,客户端仍然能够获取锁和释放锁。

分布式锁(redis的简单实现)

  1. 数据库乐观锁;
  2. 基于Redis的分布式锁;
  3. 基于ZooKeeper的分布式锁
1.加锁

最简单的方法是使用setnx命令。key是锁的唯一标识,按业务来决定命名。比如想要给一种商品的秒杀活动加锁,可以给key命名为 “lock_sale_商品ID” 。而value设置成什么呢?我们可以姑且设置成1。加锁的伪代码如下:

SETNX key value

将 key 的值设为 value ,当且仅当 key 不存在。若给定的 key 已经存在,则 SETNX 不做任何动作。SETNX 是『SET if Not eXists』(如果不存在,则 SET)的简写。

时间复杂度:O(1)
返回值:
设置成功,返回 1 。
设置失败,返回 0 。
当一个线程执行setnx返回1,说明key原本不存在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis-plus乐观和Redis分布式锁都是用于解决并发访问数据时的线程安全问题,但它们的实现方式和应用场景有所不同。 Mybatis-plus乐观是基于数据库的乐观实现机制,通过在数据表添加一个版本号字段来实现。当多个线程同时访问同一条数据时,每个线程会读取到这个版本号,并在新时将版本号作为新条件,如果版本号匹配,则执行操作;如果版本号不匹配,则说明其他线程已经修改了数据,当前线程新失败。乐观适用于高并发读取、低并发新的场景,可以减少数据库的冲突,提高并发性能。 Redis分布式锁是基于Redis实现的一种分布式锁机制。通过在Redis设置一个特定的key作为,在获取时判断该key是否存在,如果存在则表示已被其他线程占用,当前线程需要等待;如果不存在,则表示当前线程获取到了,可以执行业务操作分布式锁适用于分布式环境下的并发控制,可以保证多个节之间的数据一致性和并发安全。 对比而言,Mybatis-plus乐观是在数据库层面实现的,适用于单个数据库实例的并发控制,可以减少数据库的冲突,但并不能解决分布式环境下的并发问题。而Redis分布式锁则是基于Redis实现的,适用于分布式环境下的并发控制,可以保证多个节之间的数据一致性和并发安全。 在实际应用,选择使用哪种机制还需要根据具体场景和需求来决定。如果是单个数据库实例的并发控制,可以选择Mybatis-plus乐观;如果是分布式环境下的并发控制,可以选择Redis分布式锁
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值