Redis中的数据对象
redis对象
redis中有五种常用对象
我们所说的对象的类型大多是值的类型,键的类型大多是字符串对象,值得类型大概有以下几种,但是无论哪种都是基于redisObject实现的
redisObject的结构如下
typedef struct redisObject {
unsigned type:4; //类型 有五种,分别对应五种常见的值类型
unsigned encoding:4; // 编码,标明底层数据结构的类型
unsigned lru:LRU_BITS; /* LRU time (relative to global lru_clock) or
* LFU data (least significant 8 bits frequency
* and most significant 16 bits decreas time). */
int refcount; //引用计数
void *ptr;// 存储结构指针
} robj;
type的可选值有五种.分别是
REDIS_STRING,
REDIS_LIST,
REDIS_SET,
REDIS_ZSET ,
REDIS_HASH
encoding的可选值有八种
REDIS_ENCODING_INT | long型的整数 |
---|---|
REDIS_ENCODING_EMBSTR | embstr编码的简单动态字符串 |
REDIS_ENCODING_ROW | 简单动态字符串 |
REDIS_ENCODING_LINKEDLIST | 双端链表 |
REDIS_ENCODING_HH | 字典 |
REDIS_ENCODING_ZIPLIST | 压缩列表 |
REDIS_ENCODING_INTSET | 整数集合 |
REDIS_ENCODING_SKIPLIST | 跳跃表 |
type和encoding共同决定了数值对象的底层结构和存储
字符串对象
字符串对象的编码可以是int,embstr和row
redis中的字符串对象是最常用的数据对象之一,redis中的许多键都是采用的字符串对象
字符串类型在redis中根据情况不同有3中情况
- 对于元素都是纯数字类型的, 例如,'1','2'这种会使用int类型存储,redis默认初始化了10000个数字对象
- 对于长度小于32的字符串类型,例如'hello',redis会使用embstr类型存储数据
- 对于长度超过32的使用row存储原字符
ps: embstr类型的字符串在修改后总会变成row编码类型
列表
列表的编码可以是linkedlist或者ziplist
- 当列表对象保存的所有字符串长度小于64字节
- 当列表对象保存的元素数量小于512个的时候
这个时候会使用,ziplist来作为列表对象的编码, 当不满足这两个条件的时候使用linkedlist
ps:这两个值是更改的,list-max-ziplist-value 和 list-max-ziplist-entries
哈希对象
哈希对象的编码可以是ziplist或者hashtable
字典的每一个键和值都是一个字符串对象
- 哈希对象保存的所有键和值的长度都小于64字节
- 哈希对象保存的键值对数量小于512个的时候
满足以上两个条件,使用ziplist存储,否则采用hashtable存储
ps:这两个值是更改的,hash-max-ziplist-value 和 hash-max-ziplist-entries
集合
集合对象的编码可以是intset或者hashtable
当集合对象满足以下两个条件的时候采用intset
- 集合对象保存的元素都是整数
- 集合对象保存的元素数量不超过512个
不满足以上两个条件都是用hashtable存储
ps: 该数值可以使用set-max-intset-entries设置
有序集合
有序集合对象的编码可以是ziplist或者skiplist
有序集合对象跟前面的几个对象不大一样
typedef struct zset{
zskiplist *zsl;
dict *dict;
} zset;
zsl中保存一个跳跃表,表节点的对象即使键,score即是分值,该结构主要为 zrange,zrank等函数服务
同时还保存一个dict,dict中也保存有键和对应的分值,获取某键的函数zscore使用这个结构,
同时持有字典和跳跃表是为了性能考虑
当有序集合满足一下两个条件时候,使用ziplist编码
- 有序集合元素数量小于128
- 有序集合元素长度小于64
不能满足以上两个条件的使用skiplist
回收
redis的对象资源垃圾回收是基于引用计数
当一个对象被使用一次,引用计数增加1
当一个引用被销毁,对象的引用计数会减1
当一个对象的引用计数为0,会被销毁
对象共享
redis默认创建了0到9999的数字对象供1万个
其他用到这些对象的时候可以不用创建新对象,直接使用已有的对象
Redis中的数据对象的更多相关文章
- 往redis中存储数据是利用pipeline方法
在redis中保存数据时,保存和设置有效时间是分开写的话,如果中间出现的异常,这会导致数据永久有效,因此就可以采用pipeline方法. # 创建redis管道对象,可以一次执行多个语句 pipeli ...
- 如何将redis中的数据导入到本地MongoDB和MySQL数据库
将redis中的数据导入到本地MongoDB数据库 创建一个process_items_mongodb.py文件(文件名自定义): #!/usr/bin/env python # -*- coding ...
- 多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中【我】
多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中 package com.xxx.xx.reve.service; import java.util.ArrayL ...
- Redis 中的数据持久化策略(RDB)
Redis 是一个内存数据库,所有的数据都直接保存在内存中,那么,一旦 Redis 进程异常退出,或服务器本身异常宕机,我们存储在 Redis 中的数据就凭空消失,再也找不到了. Redis 作为一个 ...
- oracle中的数据对象
oracle中的数据对象有表.视图.索引.序列等 表的相关操作 1.创建表 方式一: 方式二:create table person( create table person1 id number(1 ...
- 读取redis中的数据时出现:MISCONF Redis is configured to save RDB snapshots
读取redis中的数据时出现:MISCONF Redis is configured to save RDB snapshots 以下为异常详细信息: Exception in thread &q ...
- 关于Redis中的字符串对象
一.SDS redis中定义Object types有5种 /* Object types */ #define REDIS_STRING 0 #define REDIS_LIST 1 #define ...
- redis 系列15 数据对象的(类型检查,内存回收,对象共享)和数据库切换
一. 概述 对于前面的五章中,已清楚了数据对象的类型以及命令实现,其实还有一种数据对象为HyperLogLog,以后需要用到再了解.下面再了解类型检查,内存回收,对象共享,对象的空转时长. 1.1 ...
- 转载:善待Redis中的数据
Redis是我们数据的保管者,我们可以随时存随时取,大的小的,重要的不重要的,它都毫无怨言的帮我们保存着,甚至有些时候,我们变得很懒,存东西进去的时候顺便还贴张纸:"过了一个星期就帮我扔了吧 ...
随机推荐
- Facebook 宣布开源Python重写后的OnlineSchemaChange
本文会简要介绍,OnlineSchemaChange在经历从PHP到Python重写后的改进和变化 文章欢迎转载,但转载时请保留本段文字,并置于文章的顶部 作者:卢钧轶(cenalulu) 本文原文地 ...
- TCP协议总结
TCP的特性 TCP提供一种面向连接的.可靠的字节流服务 在一个TCP连接中,仅有两方进行彼此通信.广播和多播不能用于TCP TCP使用校验和,确认和重传机制来保证可靠传输 TCP给数据分节进行排序, ...
- 基于webpack2.x的vue2.x的多页面站点
vue的多页面 依旧使用vue-cli来初始化我们的项目 然后修改主要目录结构如下: ├── build │ ├── build.js │ ├── check-versions.js │ ...
- java jdk中安装证书的步骤
需要注意的是:导入证书时,请确认导入的JDK为当前程序运行所用的JDK,且路径是jdk目录下的jre目录路径,非与jdk同级的jre目录 首先你可以把需要导入的证书放在keytool的同级目录下,然后 ...
- jsp自定义函数库
步骤如下: 1.创建一个函数库类,里面的方法就是标签函数库要调用的方法(必须是静态方法) package com.mdd.tag; public class JiSuan { //两个数相 ...
- 编程语言与C语言的简介
1.什么是程序 指挥计算机执行我们想要它做的动作,而依照顺序执行的一组指令 2.程序的作用是什么 指挥计算机工作 3.程序的特征 1.程序是一行一行的执行 2.是一种与计算机沟通的语言 3.程序是由特 ...
- 《高性能javascript》 --- in case of odd number of items(奇怪的条目的数量)
不知道是做着故意放的还是什么原因.总之运行后就会出现问题(奇怪的条目的数量) function merge(left, right){ var result = []; while (left.len ...
- 【图解HTTP】笔记摘要
第1章 了解Web及网络基础 根据Web浏览器(Web客户端)地址栏中指定的URL,Web浏览器从Web服务器端获取文件资源(resource)等信息,从而显示出Web页面. CERN(欧洲核子研究组 ...
- 扫描soa并输出所有服务方法
现在,大多公司都采用soa架构.那么我们怎么知道soa提供哪些服务方法呢?是通过浏览器不断的点击尝试?还是通过wcf?还是通过阅读soa接口文档,在软件开发行业,总会有文档落后于代码的情况?这些手法都 ...
- 开涛spring3(9.4) - Spring的事务 之 9.4 声明式事务
9.4 声明式事务 9.4.1 声明式事务概述 从上节编程式实现事务管理可以深刻体会到编程式事务的痛苦,即使通过代理配置方式也是不小的工作量. 本节将介绍声明式事务支持,使用该方式后最大的获益是简 ...