[Redis]常见数据和内部编码

news2024/11/19 22:48:24

相关命令

type (key)

type 命令实际返回的就是当前键的数据结构类型,它们分别是:string(字符串)、list(列 表)、hash(哈希)、set(集合)、zset(有序集合)

但是,这些这是对外的数据结构,实际上 Redis 针对每种数据结构都有自己的底层内部编码实现,而且是多种实现,这样 Redis 会在合适的场景选择合适的内部编码

object encoding (key)

在 Redis 中,你可以使用 object encoding 命令来查看特定键的编码方式。这个命令会返回该键所使用的内部编码。

Redis 数据类型和对应内部编码

数据类型  内部编码
stringstring
int
smbstr
hashhashtable
ziplist
listlinkedlist
ziplist
sethashtable
intset
zsetskiplist
ziplist

 字符串(String)

Redis 的字符串是二进制安全的,它们可以存储任何类型的数据,如文本或二进制数据。字符串的最大长度为 512 MB。

  • raw:直接存储字符串对象。当字符串长度较大时使用这种编码。
  • embstr:将字符串和 Redis 对象头部合并存储。当字符串较短(小于 44 字节)时使用这种编码,以减少内存分配次数和空间消耗。
  • int:对于可以表示为 64 位有符号整数的字符串,使用整数编码,节省存储空间。

 哈希(Hash)

哈希是一个键值对集合,通常用于存储对象。

  • ziplist:适用于小型哈希,将所有键值对存储在一个连续的内存块中。
  • hashtable:对于较大的哈希,使用哈希表编码。

列表(List)

列表是按顺序排列的字符串集合,支持从头部或尾部推入和弹出元素。

  • ziplist:适用于小型列表,将所有元素存储在一个连续的内存块中,适合存储少量元素或元素较短的列表。
  • linkedlist:对于较大的列表,使用双向链表存储,每个节点包含一个指向前后节点的指针。

quicklist是 Redis 3.2 版本引入的一种编码方式,旨在结合 ziplist 和 linklist 的优点,提供更高效的内存使用和性能表现。 

quicklist是一种将多个 ziplist链接在一起的双向链表。每个节点是一个 ziplist ,这种设计的目的是通过减少内存碎片和避免过多的内存分配来优化列表的性能。quicklist 结合了 ziplist 和 linklist 的优势,使得它在存储和操作列表时具有更好的性能和更低的内存开销。

集合(Set)

集合是无序的字符串集合,不允许重复元素。

  • intset:适用于只包含整数值的小型集合。
  • hashtable:对于大型集合或包含非整数值的集合,使用哈希表编码。

有序集合(Sorted Set)(zset)

  • ziplist:适用于小型有序集合,将所有元素和评分存储在一个连续的内存块中。
  • skiplist:对于较大的有序集合,使用跳表(skiplist)和哈希表的组合,以提供高效的范围查询和插入操作。

总结 

Redis 这样设计有两个好处:

1)可以改进内部编码,而对外的数据结构和命令没有任何影响,这样一旦开发出更优秀的内部编码, 无需改动外部数据结构和命令,例如 Redis 3.2 提供了 quicklist,结合了 ziplist 和 linkedlist 两者的优势,为列表类型提供了一种更为优秀的内部编码实现,而对用户来说基本无感知。

2)多种内部编码实现可以在不同场景下发挥各自的优势,例如 ziplist 比较节省内存,但是在列表元素比较多的情况下,性能会下降,这时候 Redis 会根据配置选项将列表类型的内部实现转换为 linkedlist,整个过程用户同样无感知。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1687106.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Cloneable 接口和深拷贝,浅拷贝

目录 一.Cloneable 接口 二.浅拷贝 三.深拷贝 四.comparable接口、 五.comparator接口 1.Java 中内置了一些很有用的接口 , Cloneable 就是其中之一 . Object 类中存在一个 clone 方法 , 调用这个方法可以创建一个对象的 " 拷贝 ". 2.来说说调用 clone 方法…

基于大型语言模型的游戏智能体

在人工智能领域,游戏代理的发展对于实现通用人工智能(AGI)至关重要。近年来,大型语言模型(LLMs)及其多模态版本(MLLMs)的进展为游戏代理的进化和能力提升提供了前所未有的机遇。这些…

Django自定义模板标签与过滤器

title: Django自定义模板标签与过滤器 date: 2024/5/17 18:00:02 updated: 2024/5/17 18:00:02 categories: 后端开发 tags: Django模版自定义标签过滤器开发模板语法Python后端前端集成Web组件 Django模板系统基础 1. Django模板语言概述 Django模板语言(DTL&…

Elasticsearch 分析器的高级用法二(停用词,拼音搜索)

Elasticsearch 分析器的高级用法二(停用词,拼音搜索) 停用词简介停用词分词过滤器自定义停用词分词过滤器内置分析器的停用词过滤器注意,有一个细节 拼音搜索安装使用相关配置 停用词 简介 停用词是指,在被分词后的词…

巨亏22亿还能上市?瑞幸为何越亏越值钱?剖析资本破局的商业思维

瑞幸咖啡 18个月登上纳斯达克 13个月退市 19个月,粉单市场股价再次翻了8倍 这个技术性“上市”无常的产品是谁? 其实现在这个笑贫不笑娼的社会 如果我说:我们公司上市了,悲催又退市了。我朋友会说:工资没降吧?…

信创数据库有哪些?哪家好?堡垒机支持吗?

当今时代,数据已经成为了企业最宝贵的资产,因此数据库厂商也是不断增加。这不不少小伙伴在问,信创数据库有哪些?哪家好?堡垒机支持吗? 信创数据库有哪些? 1、达梦数据库 2、openGauss 3、人大…

Mac Pro中的开源虚拟机UTM安装ubuntu(Applce M1,M2芯片)(1)

UTM安装ubuntu(Applce M1,M2芯片)(2)链接: https://blog.csdn.net/qq_38382925/article/details/139158763?spm1001.2014.3001.5502 MacPro安装UTM 1 UTM 下载UTM虚拟机链接: https://mac.getutm.app/ 建议官网下载: 下载 U…

Codesys软件做EtherNET/IP主站与HT3S-EIS-MDN网关通讯步骤

Codesys软件做EtherNET/IP主站与HT3S-EIS-MDN网关通讯步骤 打开codesys软件,新建项目,选择标准项目进入界面后选择CODESYS Control Win v3 x64 ,点击确定。 3.在桌面找到显示隐藏图标,找到如下图所示图标,右击在弹出…

查看bond接口详细信息

cat /proc/net/bonding/bondX 命令用于查看 Linux 系统中的网络绑定(bonding)接口的详细信息。在该命令中,bondX 是网络绑定接口的名称,其中 X 是数字,表示具体的网络绑定接口编号。 输出内容详解: 1. E…

java面试框架篇(Spring常见问题、SpringBoot、SpringMVC、mybatis经典问题、SpringCloud组件)

文章目录 面试专题-java框架篇1. spring常见问题1.1. spring是什么?1.2. 谈谈你对AOP的理解1.3. 谈谈你对IOC的理解1.4. Spring Boot、 Spring MVC和Spring有什么区别1.5. spring bean 生命周期1.6. spring事务传播机制有哪些?1.7. 循环依赖1.8. spring框架中使用了哪些设计模…

并网逆变器学习笔记9---VSG控制

参考文献:《新型电力系统主动构网机理与技术路径》 “构网技术一般包含下垂控制,功率同步控制,虚拟同步机控制,直接功率控制,虚拟振荡器控制 等。其中,虚拟同步机技术,即 VSG,因其物…

webgl开发家居设计软件

WebGL是一种在网页浏览器中渲染3D图形的JavaScript API,它基于OpenGL ES标准,允许开发者创建和显示交互式的3D图形。开发基于WebGL的家居设计软件可以为用户提供一种全新的、沉浸式的家居设计体验。以下是开发此类软件的一些关键步骤和特点。北京木奇移动…

【问题记录】QT“类型强制转换“:无法从“ATL::CString“转换为“LPCWSTR“

一,问题现象 环境:VS2019QT 报错提示:“类型强制转换”:无法从"ATL::CString"转换为"LPCWSTR" 二,解决方法 打开项目属性,设置字符集,如下所示:

某勾求职网逆向分析

搜索目标: aHR0cHM6Ly93d3cubGFnb3UuY29tL3duL2pvYnM/cG49MSZweD1kZWZhdWx0JmZyb21TZWFyY2g9dHJ1ZSZrZD0lRTYlOTUlQjAlRTYlOEQlQUUlRTUlODglODYlRTYlOUUlOTA= 抓包分析 请求和返回都是加密的 请求头部也有未知参数 跟栈分析 请求和返回是一个AES加密,加密的KEY是session s…

ruoyi前端获取用户信息

vue中获取当前用户信息 :头像,用户名,id,权限,token等 // 获取当前用户信息 用户名等var user this.$store.state.user;console.log("用户信息####", user);

DLRover:蚂蚁集团开源的AI训练革命

在当前的深度学习领域,大规模训练作业面临着一系列挑战。首先,硬件故障或软件错误导致的停机时间会严重影响训练效率和进度。其次,传统的检查点机制在大规模训练中效率低下,耗时长且容易降低训练的有效时间。资源管理的复杂性也给…

Nginx(负载均衡,反向代理)

1.什么是nginx Nginx(“engine x”)是一个高性能的HTTP和反向代理服务器,特点是占有内存少,**并发**能力强,事实上Nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用Nginx网站用户有&#…

Codeforces Round 943 (Div. 3)

欢迎关注更多精彩 关注我,学习常用算法与数据结构,一题多解,降维打击。 Codeforces Round 943 (Div. 3) 题解 题目列表:https://codeforces.com/contest/1968 A https://codeforces.com/contest/1968/problem/A 题目大意 给…

【教学类-58-01】黑白三角拼图01(2*2宫格)256种

背景需求: 中班益智区素材:三角形变魔术 - 小红书自制益智区教玩具:三角形变魔术,共24题 玩法一:根据图示在空白格子里摆放。 玩法二:根据图示在空白格子里用黑笔涂。##自制玩具益智区 #幼儿园益智区 #中班…

Color预设颜色测试

"AliceBlue", "获取 ARGB 值为 的系统 #FFF0F8FF定义颜色。", "AntiqueWhite", "获取 ARGB 值为 的系统 #FFFAEBD7定义颜色。", "Aqua", "获取 ARGB 值为 的系统 #FF00FFFF定义颜色。", "Aquamarine"…