14. Redis底层实现 Set

Set

Redis用intset或hashtable存储set。如果元素都是整数类型,就用intset存储。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis分布式锁是一种常用的分布式系统中实现互斥访问的机制。其底层原理可以通过以下几个步骤来介绍: 1. 获取锁:客户端通过执行SET命令尝试在Redis中设置一个特定的键值对作为锁。如果该键不存在,则表示获取到了锁,可以执行后续操作。如果该键已经存在,则表示锁已经被其他客户端持有,需要等待或者进行重试。 2. 设置过期时间:为了避免锁被持有后无法释放的情况,需要为锁设置一个过期时间。客户端在获取到锁之后,通过执行EXPIRE命令为锁设置一个合适的过期时间。这样即使持有锁的客户端发生故障或者意外退出,锁也会在一定时间后自动释放。 3. 释放锁:当客户端完成了对共享资源的操作后,需要释放锁。客户端通过执行DEL命令来删除锁对应的键值对,从而释放锁供其他客户端使用。 需要注意的是,Redis分布式锁的实现需要考虑以下几个问题: 1. 锁竞争:多个客户端同时尝试获取锁时可能会发生竞争。为了避免多个客户端同时获取到锁,可以使用SETNX命令来保证只有一个客户端能够成功获取到锁。 2. 锁误释放:如果客户端在获取到锁之后发生故障或者意外退出,锁可能无法正常释放。为了解决这个问题,可以为锁设置一个合适的过期时间,确保即使持有锁的客户端发生故障,锁也会在一定时间后自动释放。 3. 锁重入:某些场景下,同一个客户端可能需要多次获取同一个锁。为了支持锁的重入,可以为每个客户端维护一个计数器,记录该客户端获取锁的次数,并在释放锁时递减计数器。只有当计数器为0时,才真正释放锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值