redis教程3 (特性以及五种数据类型的编码特点适用场景)
创始人
2025-05-29 07:21:17
0

redis 特性以及五种数据类型的编码特点适用场景

    • redis特性优势(快)
    • string类型的编码及适用场景
    • hash 的编码及适用的类型
    • list的编码及适用场景
    • 集合set的内部编码及使用场景
    • 有序集合zset的编码及适用场景

redis特性优势(快)

  1. 纯内存访问, redis在不进行持久化配置的时候, 数据存在内存中, 内存的响应时间大约为100纳秒, 非常快, 每秒可以处理上万访问。
  2. 非阻塞I/O, redis使用epoll 作为I/O 多路复用技术的实现, 再加上redis自身的事件模型epoll中的连接, 读写, 关闭都转换为事件,不再网络I/O上浪费时间
  3. 采用单线程的情况下, 避免了线程之间切换, 竞态生成等消耗

string类型的编码及适用场景

  1. string 的编码

redis 会根据当前值的类型和长度决定使用那种内部编码实现
1. int 为8字节的长整形
2. embstr:小于等于39个字节的字符串
3. raw:大于39个字节的字符串

set key 8856
object encoding key 
  1. string 的使用场景
  1. 可以做缓存
    redis 可以设置ley-value形式, 做缓存, 见效数据库的压力
  2. 可以计数
    使用incr针对key的访问进行计数, 比如统计文章的浏览量等
  3. 共享Session
    保障redis的高可用, 高扩展性, 将用户的数据存在redis里面, 所有系统都在redis里面取用户的认证信息
  4. 限速
    比如限制用户每分钟只能访问5次

hash 的编码及适用的类型

  1. 内部编码
  1. ziplist(压缩列表) 当哈希类型的元素个数小于hash-max-ziplist-entries 配置(默认512), 同时所有值都小于hash-max-ziplist-value配置(默认64字节) 更加紧凑, 可以实现多个元素的连续存储, 更加节省内存
  2. hashtable 当哈希类型无法满足ziplist的条件时, redis就会使用hashtable实现, 在这之后, ziplist的读写能力就会下降, 而hashtable的时间复杂度为O(1)
  1. 适用场景
  1. 可以实现一个key 多个field-value的对象存储

list的编码及适用场景

  1. 内部编码
  1. ziplist(压缩列表) 当列表的元素个数小于hash-max-ziplist-entries 配置(默认512), 同时所有值都小于hash-max-ziplist-value配置(默认64字节) redis会使用ziplist来节省内存
    linkedlist(链表) 当无法满足ziplist的时候就用linkedlist
  1. 适用场景
  1. 消息队列
    redis的lpush+brpop可以实现阻塞队列, 生产者使用lpush在队列的左侧插入, 然后多个消费者使用brpop在队列的末尾抢元素。
  2. 文章列表
    每个用户有自己的文章列表, 且需要分页, list可以支持有序并且可以范围查询

集合set的内部编码及使用场景

  1. 内部编码
  1. intset ( 整数集合) 当集合中的元素都是整数且元素个数小于set-max-intset-entries 配置(默认512)
  2. hashtable 当不满足intset条件时, 使用hashtable来实现
  1. 使用场景
  1. 统计相同爱好的用户

有序集合zset的编码及适用场景

  1. 内部编码
  1. ziplist(压缩列表) 当集合的元素个数小于hash-max-ziplist-entries 配置(默认512), 同时所有值都小于hash-max-ziplist-value配置(默认64字节) 更加紧凑, 可以实现多个元素的连续存储, 更加节省内存
    skiplist (跳跃表) 当不满足ziplist 的条件时, 适用skiplist
  1. 适用场景

可以用于统计点赞量等

相关内容

热门资讯

Altium Designer... 目录Altium Designer(AD)软件使用记录15-PCB布线部分之优化和DRC处理一、线路...
通俗易懂了解Hadoop(更新... 从本书第5、6、7、8章,学习云计算开发相关知识 这是第五章 文章目录Hadoo...
LeetCode-198. 打... 目录暴力递归动态规划 题目来源 198. 打家劫舍 暴力递归 class Solution {pub...
js学习11(客户端存储) 目录 web storage IndexDB   web storage ### 前言࿱...
target.closest妙... 首先看下MDN:Element.closest() - Web APIs | MDN ...
并发编程(一)-Thread ... 一、什么是线程线程(英语:thread)是操作系统能够进行...
小白学Pytorch系列--T... 小白学Pytorch系列–Torch API (9) Spectral Ops stft 短时傅立...
Java二叉树的前中后序遍历 Java二叉树的前中后序遍历1.前序遍历1.1前序遍历概念1.2前序遍历习题2.中序遍历2.1中序遍...
遗传算法原理及案例解析 一、遗传算法原理 遗传算法—进化算法(Genetic Algorithm GA...
朴素贝叶斯学习报告 报告 朴素贝叶斯算法描述公式:  案例计算步骤: 一个数据集中有两个样本...
算法小课堂(一)暴力枚举 、 目录 一、概念 1.1相关概念 1.2应用场景 1.3局限性 二、相关问题 2.1例题1:统计 ...
OpenHarmony之doc... Docker使用示例 docker移植至OpenHarmony的过程可参考:https...
懒人专用高并发:Actor模型 传统多线程实现方式 public class MultiThreadExample implemen...
WEB安全 HTML基础 1.简单的HTML页面架构 charset  编码 gbk gbk2...
算法基础---基础算法(二) 文章目录 高精度         高精度加法高精度减法高精度乘法高精度除法前缀和 一维前缀和二维前缀...
【Docker】镜像的原理定制... 文章目录镜像是什么UnionFS(联合文件系统)Docker镜像加载原理...
vue3常用 Composit... 二、常用 Composition API 官方文档 1.拉开序幕的setup语法糖 理解࿱...
【MySQL】实验二 简单查询 目录 1. 查询课程代号为1301的成绩不及格的成绩信息 2. SQL查询:查询employee的j...
spring启动时加载外部配置... 平常同学们使用spring搭建工程时一些应用配置信息(例如数据库的连接配置、中间件的连...
《他是谁》爆火,优酷的成功并非... 今年国产电视剧市场又进入了新一轮的爆款时代,观众在前面刚送走《三体》《狂飙》ÿ...