Redis五大基础类型解析
1.String类型
特征:即存储字符串的类型,单个字符串存储量最大不超过512MB
常用业务场景:⽤来存储JSON序列化之后对象
底层编码:
int编码
数据结构特点:ptr指针直接指向字符串常量池中对应字符串地址,而且数组中元素只能为数字
使⽤要求:每⼀个字符必须是数字
EmbStr编码
数据结构特点:采⽤简单动态字符串结构,这种结构的特征就在于是⼀个可扩容的字符数组,由当前已使⽤⻓度字段,当前未使⽤⻓度字段以及⼀个字符数组组成。
扩容规则:当字符数组大小小于1MB时,将总长度进行翻倍,如果字符数组大小大于1MB,那么每次增加1MB的长度
使用要求:当字符串大小小于32MB时候,采用的编码
数据结构内存地址所在:为RedisObject对象后的连续内存
Raw编码
数据结构特点:同样采用简单动态字符串作为数据结构
使用要求为当字符串大小超过32MB的时候,自动转为RAW编码
数据结构内存地址所在:不和RedisObject对象在⼀起,而是在内存中其他随机地方
重点:由于EmbStr和Raw编码中简单动态字符串结构(SDS)内存地址不同,所以最开始⽣成String对象的时候,分配内存的次数也不同,由于EmbStr的RedisObject对象和SDS对象是连续的,所以⼀起分配内存就行,但是raw需要两次内存分配
2.List类型
特征:有序,可重复列表。每个List类型可以插入(2的32次方)-1个元素
常⽤业务场景
最新与最老数据的TOP显示:由于底层采用双向链表/压缩列表的方式进行存储,均能获取头节点和尾节点指针,每个节点均有前后指针的关系,非常适合进行操作头部与尾部节点
消息队列:即⽣产者可以使⽤push方法往List类型的头部插入信息,然后消费者通过pop对List类型的尾部进行消费
底层编码:
ZipList编码
数据结构特点:即⼀段连续的内存数组,但是和普通的数组不同,他的每⼀个元素空间都是根据其中存储的元素大小来规定的,并不是死板的固定大小,并有记录当前最后⼀个元素位置的指针。
数据结构特点:即⼀段连续的内存数组,但是和普通的数组不同,他的每⼀个元素空间都是根据其中存储的元素大小来规定的,并不是死板的固定大小,使⽤要求:即当每⼀个元素大小不超过64个字节,总元素个数不超过512个并有记录当前最后⼀个元素位置的指针。
数据结构内存地址所在:作为RedisObject对象后的连续内存,所以⽣成List对象时,此编码只⽤分配⼀次内存
LinkedList编码
数据结构特点:就是双向链表
使⽤要求:当不满⾜zipList编码要求的时候,就会变成LinkedList编码
数据结构内存地址所在:不和RedisObject在⼀起,⽽是在内存中的任意位置
3.Hash类型
特征:每个Hash类型可以存放(2的32次⽅)-1个键值对
常⽤业务场景:购物车的管理,即使⽤⽤户id作为key值,⽤商品id作为field字段,⽤商品数量作为value,那么我们可以使⽤hgetAll指令完成购物⻋全选,hdel删除指定商品等等操作
底层编码:
ZipList编码
数据结构特点:和List类型采⽤此编码时运⽤不太⼀样,Hash类型会把field-value键值对连续的插⼊到压缩列表中,从⽽完成不同键值对的存储
使⽤要求:即当每⼀个元素⼤⼩不超过64个字节,总元素个数不超过512个
数据结构内存地址所在:作为RedisObject对象后的连续内存,所以⽣成List对象时,此编码只⽤分配⼀次内存
Hashtable编码
数据结构特点:底层为哈希表数据结构,⽤以存储field-value键值对
使⽤要求:当不满⾜zipList编码要求的时候,就会变成LinkedList编码
4.Set类型
特征:为⽆序,⽽不可重复集合,可以存放(2的32次⽅)-1个元素
常使⽤业务场景:
元素去重:即⼤量元素去重操作会占⽤⼤量CPU资源,那么把这些数据存储到Set类型中,即可完成去重操作
共同好友等:把⼀个⽤户的好友和另⼀个⽤户的好友进⾏交集处理,得到他们的公同好友,然后进⾏推荐
底层编码:
Inset编码
数据结构特点:即由整型数组组成的连续内存(此数组按元素⼤⼩进⾏排序),但是除了整形数组外,还有有当前数组包含的元素数量以及采⽤整形的编码,可分为int16,int32,int64.分别是整形数组中运⾏存放数值的⼤⼩
使⽤要求:元素个数⼩于512个,⽽且集合内元素全为数字
数据结构内存地址所在:和RedisObject相连的连续内存
HT编码
数据结构特点:由Value值为空的Hashtable结构组成,被称为字典。
使⽤要求:当不满⾜inset编码要求的时候,就会变成HT编码
5.ZSet类型
特征:为有序,⽽不可重复集合,可以存放(2的32次⽅)-1个元素
常使⽤业务场景:热⻔数据TOP排⾏榜,即利⽤Zset类型,有序不重复特点,把重复的数据进⾏去重并且使⽤score字段排序后,从⼩到⼤排序,反序即可得到热⻔数据TOP排⾏榜
底层编码:
ZipList编码
数据结构特点:压缩列表的另⼀种使⽤,即使⽤⼀个新增的score字段来决定元素在压缩列表中的位置,默认从⼩到⼤
使⽤要求:元素单个⼤⼩不能超过64字节,压缩数组⻓度不能超过128个元素
数据结构内存地址所在:和RedisObject相连的连续内存
skipList编码
数据结构特点:通过跳表与Hashtable的集合编码,利⽤跳表存储hash表中的节点来完成有序,操作主要还是在hash表中,跳表中的⼤⼩由Score字段来决定
使⽤要求:当不满⾜zipList编码要求的时候,就会变成skipList编码
相关文章:
![](https://www.ngui.cc/images/no-images.jpg)
Redis五大基础类型解析
1.String类型 特征:即存储字符串的类型,单个字符串存储量最大不超过512MB 常用业务场景:⽤来存储JSON序列化之后对象 底层编码: int编码 数据结构特点:ptr指针直接指向字符串常量池中对应字符串地址,而…...
![](https://www.ngui.cc/images/no-images.jpg)
在CSDN学Golang云原生(服务网格istio)
一,在Kubernetes上部署istio 在Kubernetes上部署istio,可以按照以下步骤进行: 安装Istio 使用以下命令从Istio官网下载最新版本的Istio: curl -L https://istio.io/downloadIstio | ISTIO_VERSION<VERSION> sh - 其中&…...
![](https://www.ngui.cc/images/no-images.jpg)
Golang 获取本地 IP 地址方法
在 Golang 中,使用 net 包可以很方便地获取到本机IP地址。 借助 net.InterfaceAddrs 方法 简单示例代码如下: package mainimport ("fmt""net" )func main() {addrList, err : net.InterfaceAddrs()if err ! nil {panic(err)}for…...
![](https://img-blog.csdnimg.cn/40b5e3074ab44b13b3eace4a8ab157bb.gif)
抖音seo短视频账号矩阵系统技术开发简述
说明:本开发文档适用于抖音seo源码开发,抖音矩阵系统开发,短视频seo源码开发,短视频矩阵系统源码开发 一、 抖音seo短视频矩阵系统开发包括 抖音seo短视频账号矩阵系统的技术开发主要包括以下几个方面: 1.前端界面设…...
![](https://img-blog.csdnimg.cn/c6509d9d3a8e4a9e916a60fd9abca45e.png)
运维高级--shell脚本完成分库分表
为什么要进行分库分表 随着系统的运行,存储的数据量会越来越大,系统的访问的压力也会随之增大,如果一个库中的表数据超过了一定的数量,比如说MySQL中的表数据达到千万级别,就需要考虑进行分库分表; 其…...
![](https://www.ngui.cc/images/no-images.jpg)
Mysql 忘记密码怎么重置密码(详细步骤)
每种方法都有其适用的情况,根据具体情况选择合适的方法。无论选择哪种方法,请务必在重置密码后及时删除临时用户并重新启动 MySQL 服务。 一、使用 mysqladmin 重置密码 停止服务 # systemctl 启动的使用这个停止 $ sudo systemctl stop mysql# mac 本机…...
![](https://img-blog.csdnimg.cn/bec187dcf3794afb97fe2ea3b7180fa2.png)
机器学习深度学习——图像分类数据集
👨🎓作者简介:一位即将上大四,正专攻机器学习的保研er 🌌上期文章:机器学习&&深度学习——softmax回归(下) 📚订阅专栏:机器学习&&深度学习…...
![](https://s3-us-west-2.amazonaws.com/secure.notion-static.com/4f7d2562-49df-4956-9ae7-8351c56d1820/Untitled.png)
【PWN · 栈迁移】[BUUCTF]ciscn_2019_es_2
第一道栈迁移题目,跌跌撞撞理解了 前言 当前溢出可用空间比较少时(极端情况下仅能覆写ebp和ret),可以通过栈迁移的方式,扩大shellcode的容纳空间,其核心是将esp移动到一段shellocode开头。而esp总是由ebp赋…...
![](https://www.ngui.cc/images/no-images.jpg)
网络编程(13): 网络通信常用命令(后续待补充)
ifconfig 一般用于查看网卡信息 ping 一般用于侦测本机到目标网络主机的网络是否通常: ping ip/域名 telnet 可以用于指定ip地址和端口的侦听服务是否存在:telnet ip port, 也可以模拟客户端给服务器发数据 netstat 用于查看网络连接状态 -a: 显示所有选项 -t&#…...
![](https://img-blog.csdnimg.cn/f322a4a68dd14d2ea864a16c1daf7103.png#pic_center)
flask创建数据库连接池
flask创建数据库连接池 在Python中,您可以使用 Flask-SQLAlchemy 这个扩展来创建一个数据库连接池。Flask-SQLAlchemy 是一个用于 Flask 框架的 SQLAlchemy 操作封装,实现了 ORM(Object Relational Mapper)。ORM 主要用于将类与数据库中的表建立映射关系…...
![](https://img-blog.csdnimg.cn/218694ffae7447f2babd3817770ab72d.png)
C语言手撕顺序表
目录 一、概念 1、静态顺序表:使用定长数组存储元素。 2、动态顺序表:使用动态开辟的数组存储 二、接口实现 1、对顺序表的初始化 2、对数据的销毁 3、对数据的打印 4、检查是否需要扩容 5、尾插 6、头插 7、尾删 8、头删 9、在pos位置插入x …...
![](https://www.ngui.cc/images/no-images.jpg)
常见的排序算法
常见的排序算法 常见的排序算法包括: 冒泡排序(Bubble Sort):依次比较相邻的元素,将较大的元素交换到右侧,逐步将最大元素移动到末尾。插入排序(Insertion Sort):将数组…...
![](https://img-blog.csdnimg.cn/c7db2562c21849609346242897a99f21.png)
C#如何使用SQLite数据库?
文章目录 0.引言1.SQLite工具准备2.创建窗体项目并添加SQLite的命名空间3.编写使用SQLite代码4.结果展示 0.引言 SQLite是一个轻量级的嵌入式数据库,它的库文件非常小巧,不需要独立的服务器进程或配置。这使得它非常适合在资源受限的环境中使用ÿ…...
![](https://img-blog.csdnimg.cn/ddd3aac94f43422fa35b5024212e3906.png#pic_center)
如何将表格中的状态数据转换为Tag标签显示
考虑到系统前端页面的美观程度,通常通过Tag标签来代替某条数据中的状态信息。仅通过一点操作,便能够使得页面美观程度得到较大提升,前后对比如下所示。代码基于Vue以及Element-ui组件实现。 修改前: 修改后: 修改前…...
![](https://img-blog.csdnimg.cn/8f9b9a4cd08c47a2ab7744a8ef97553b.png)
centos中修改防火墙端口开放配置
1、直接进入文件修改 vim /etc/sysconfig/iptables 2、添加需要开放的端口 (1)添加需要开放的单个端口 4001 -A INPUT -m state --state NEW -m tcp -p tcp --dport 4001 -j ACCEPT (2)添加需要开放的某个网段端口 4001:4020 …...
![](https://img-blog.csdnimg.cn/ee3faf5f07924896acca330c525345b6.png)
程序设计 算法基础
✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。 🍎个人主页:小嗷犬的个人主页 🍊个人网站:小嗷犬的技术小站 🥭个人信条:为天地立心&…...
![](https://img-blog.csdnimg.cn/6768aefca2d94aeca75dc9f695781911.png)
【数据结构】之十分好用的“链表”赶紧学起来!(第一部分单向链表)
💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤 📃个人主页 :阿然成长日记 …...
![](https://img-blog.csdnimg.cn/3221201cb61b4e068383e49025cd9505.png)
ubuntu开机自启动
ubuntu开机自启动 1、建一个test.sh脚本,并写入 #!/bin/sh gnome-terminal -x bash -c ‘cd /home/文件路径/;python3 main.py’ exit 0 2、:wq!保存 3、创建rc-local.service文件(sudo vim /etc/systemd/system/rc-local.service)…...
![](https://www.ngui.cc/images/no-images.jpg)
Git将其他分支合并至主分支
主要思想: 把分支代码合并到master,合给谁,就先切换到谁的分支 1. 当前分支是dev,开发完成后,需要合并到master分支 先把该提交的提交,需要push的push完成后,再切换分支。 否则也会告诉你要提交…...
![](https://www.ngui.cc/images/no-images.jpg)
Python+request+pytest 接口自动化测试框架入门(与unittest的比较)
1. Pythonrequestpytest 接口自动化测试框架入门 - 简书 pytest和unittest的比较: pytest是一个非常成熟的全功能的Python测试框架,主要有以下几个特点: 简单灵活,容易上手支持参数化能够支持简单的单元测试和复杂的功能测试&a…...
![](https://img-blog.csdnimg.cn/7ee52d73e5964f50a250aaeb3d26b614.png)
数据结构——复杂度
总有一天你要一个人,再暗夜中,向那座桥走过去 文章目录 一、算法的复杂度 考察形式范例 二、算法的时间复杂度 大O的渐进表示法 常见的复杂度对比 例题:消失的数字 题目的三种思路 1.排序遍历 2.减法 3.单身狗思想 三、空间复杂度…...
![](https://img-blog.csdnimg.cn/094720b12ccd4b4995bcaad71ea1be52.png)
使用goldengate 迁移Oracle到postgresql
环境: --源端: IP:10.0.4.16 hostname:tencent Oracle数据库版本:12.2.0.1.0 ogg for oracle版本:19.1.0.0.4 SID:orcl --目标端: IP:10.0.4.16 hostname&#…...
![](https://img-blog.csdnimg.cn/5a119b0b1f404d2292eea90b9e93b8d0.png)
ESP-C3入门20. CentOS开发环境及Jenkins流水线
一、准备环境 CentOS8已经正常安装Jenkins 二、升级 cmake cmake 升到 3.16以上。 cmake --version # 安装 g sudo yum install gcc-c export CXXg# 安装 CMake 的依赖项 sudo yum install -y openssl-devel# 下载 CMake 源码并进行编译安装 wget https://github.com/Kitwa…...
![](https://img-blog.csdnimg.cn/b12b7fb3c03e4ff6b5fc2c942d7ecc08.png)
服务器被爬虫恶意攻击怎么办?
在有预算的情况可以采购第三方服务防火墙,没钱就使用开源的WAF进行防护。 # WAF防火墙的基本防护原理 WAF(Web 应用防火墙)可以使用多种技术来防止恶意爬虫攻击,例如: 1. 黑名单:WAF 可以使用黑名单技术来…...
![](https://img-blog.csdnimg.cn/f4b3cb52f18545ce8ecd0550dbd077e4.png)
JavaScript正则表达式之座机号/手机号验证校验规则
引用:https://www.bilibili.com/read/cv18300539/ 本文对利用正则表达式对手机号码进行了验证 支持格式: 座机 :xxx-xxxxxxxx、xxxxxxxxxxxx …座机区号的横杠可有可无 手机:xxxxxxxxxxx JavaScript: var: checkPhone (rule,…...
![](https://img-blog.csdnimg.cn/16e8bbb87622490a863a9876317ecc60.jpeg)
黑客学习手册(自学网络安全)
一、首先,什么是黑客? 黑客泛指IT技术主攻渗透窃取攻击技术的电脑高手,现阶段黑客所需要掌握的远远不止这些。 二、为什么要学习黑客技术? 其实,网络信息空间安全已经成为海陆空之外的第四大战场,除了国…...
![](https://www.ngui.cc/images/no-images.jpg)
获取非叶子节点的grad(retain_grad()、hook)【为了解决grad值是None的问题】
在调试过程中, 有时候我们需要对中间变量梯度进行监控, 以确保网络的有效性, 这个时候我们需要打印出非叶节点的梯度, 为了实现这个目的, 我们可以通过两种手段进行, 分别是: retain_grad()hook 不过我感觉“hook”比“retain_grad()”要麻烦.....,所以我感觉还是…...
![](https://img-blog.csdnimg.cn/cefb6743a4484b21b87d3d084b6a7617.png)
JMeter(八):响应断言详解
响应断言 :对服务器的响应进行断言校验 (1)应用范围: main sample and sub sample, main sample only , sub-sample only , jmeter variable 关于应用范围,我们大多数勾选“main sample only” 就足够了,因为我们一个请求,实质上只有一个请求。但是当我们发一个请求时,…...
![](https://www.ngui.cc/images/no-images.jpg)
【网络编程】IO复用的应用一:非阻塞connect
在connect连接中,若socket以非阻塞的方式进行连接,则系统内设置的TCP三次握手超时时间为0,所以它不会等待TCP三次握手完成,直接返回,错误为EINPROGRESS。 所以,我们可以通过判断connect时返回的错误码是…...
![](https://img-blog.csdnimg.cn/2b312574e7da483fb663e61a2a0206ef.png)
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
🐌个人主页: 🐌 叶落闲庭 💨我的专栏:💨 c语言 数据结构 javaweb 石可破也,而不可夺坚;丹可磨也,而不可夺赤。 Spring注解开发 一、注解开发定义Bean二、纯注解开发Bean三…...
![](https://yqfile.alicdn.com/8cdc800a44fffe9d13d0faeb86f25ff75b75525e.png)
培训网站计时怎么破/济南seo排名优化推广
事务码MD61创建独立的生产计划...
![](/images/no-images.jpg)
大淘客网站怎样做百度推广/软件网站排行榜
做一个小例子演示滤镜的动态效果 在舞台建两个元件或导入两张图片到舞台再转化为元件,分别取实例名apple01和apple02; var blurSpeed:Number 1;//首先使用动画滤镜 var bevelSpeed:Number 5;//为两个苹果添加MOUSE_OVER 事件侦听 apple01.addEventList…...
![](/images/no-images.jpg)
兰溪高端网站建设公司/百度官方电话号码
本实用新型为一种双快锁体,具体涉及锁具领域。背景技术:门锁广泛地被应用于生活中,尤其是随着人们安全意识的提高,对门锁的安全性和使用的便捷性的要求也越来越高。现在的锁体类型多样,但是材质上会选用便宜的材料&…...
![](/images/no-images.jpg)
wordpress 显示pdf/人工智能培训机构哪个好
上一期与大家探讨了做自媒体需要硬件与软件,今天接着和大家探讨做自媒体的心得二,做自媒体如何赚钱盈利,做自媒体该怎么样去做?从哪方面去做等问题。 怎么做自媒体,做自媒体如何赚钱盈利 一、是做图文自媒体 图文就是…...
![](/images/no-images.jpg)
淄博网站公司/网络营销渠道可分为哪些
猜字游戏是一款益智游戏,喜欢玩具有挑战性单词游戏的你就可以来体验一下了,给你一个字母板。尝试通过想象相邻字母的单词。您将获得一个分数,根据您使用的字母,你已经使用了多少个字母,并以这些字母相关联的任何修饰符…...
![](https://images2015.cnblogs.com/blog/817161/201701/817161-20170114140733681-1058760194.png)
网站建设上海公司/黑帽seo工具
Linux_安装 总结: 分区-->格式化-->起一个设备文件名(逻辑分区一定从5开始)-->指定挂载点(必须是空的目录名称作为盘幅) posted 2017-01-14 14:08 douzujun 阅读(...) 评论(...) 编辑 收藏...