Redis压缩列表ziplist

一个压缩列表my_zl的组成

  • 属性 字节数 含义
  • zlbytes 4B-my_zl全部内容占用的内存字节数
  • zltail 4B 尾节点的偏移,O(1)地找到尾节点,不然要从头遍历
  • zllen 2B my_zl中节点的数量,即后面entry的数量
  • entry0 字节数不定 my_zl中的一个节点
  • entry1
  • entryN
  • zlend 1B 结束符 0xFF

一个压缩列表节点的组成

  • previous_entry_length 1B或5B 前一个节点的字节长度
  • encoding 1B或2B或5B content保存的数据类型以及长度
  • content 长度不定 一个字节数组或一个整数

ziplist编码的List

lpush rpush分别向头和尾添加节点

ziplist编码的Sorted Set

存储格式

| member-1 | score-1 | member-2 | score-2 | … | member-N | score-N |

void zaddGenericCommand(redisClient *c, int incr) 

按score的大小顺序存储

  • 添加:遍历,找第一个比score大的节点,插入到它前面
  • 查找:遍历ziplist
  • 修改:删除原来的member和score

ziplist编码的Hash表

存储格式

| field-1 | value-1 | field-2 | value-2 | … | field-N | value-N |

 int hashTypeSet(robj *o, robj *field, robj *value)

与Hash无关的存储,先来后到的存储顺序

  • 添加:添加到ziplist末尾,先添加field,后添加value
  • 查找:遍历整个ziplist
  • 修改:找到field节点,删除旧的value节点,在field后插入新的value节点
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值