redis的内部编码和数据结构类型

1.redis原理
reids使用了单线程架构和I/O多路复用模型来实现性能的内存数据库服务

2.简化的工作流程
发送命令,执行命令,返回结果

3.单线程处理但处理快速的原因

  • 纯内存访问
  • 非阻塞I/O,redis使用epoll作为I/O多路复用技术
  • 单线程避免了线程切换和竞态产生的消耗

redis内部编码
1)string内部编辑

  • raw:大于的39个字节的字符串
  • int:8个字节的长整型
  • embstr:小于等于39个字节的字符串

2)hash内部编码

  • hashtable:value大于64字节或者filed个数超过512个
  • ziplist:field个数比较少且没有大的value情况下使用

3)list内部编码

  • linkedlist:当列表类型无法满足ziplist条件时,redis会使用linkedlist作为列表的内部实现
  • ziplist:元素个数比较少(没有超过512个)或者没有大元素(没有超过64字节);

4)set内部编码

  • hashtable:元素个数超过512个或者元素不为整数
  • intset:元素个数比较少且为整数

5)zset内部编码

  • skiplist:元素个数较少(不超过128)且元素小于64个字节
  • ziplist:元素个数超过128或某元素大于64字节

redis数据结构类型

  • string:字符串
  • hash:哈希
  • list:列表
  • set:集合
  • zset:有序集合

各种类型对比

数据结构是否允许重复元素是否有序有序实现方式应用场景
列表索引下标时间轴,消息队列
集合标签,社交
有序集合分值排行榜系统,社交
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值