上一页 1 ··· 12 13 14 15 16 17 18 19 20 ··· 39 下一页
摘要: Redis 基于 Reactor 模式开发了自己的网络事件处理器: 这个处理器被称为文件事件处理器(file event handler): 文件事件处理器使用 I/O 多路复用(multiplexing)程序来同时监听多个套接字, 并根据套接字目前执行的任务来为套接字关联不同的事件处理器。 当被监 阅读全文
posted @ 2020-12-24 17:08 Tracydzf 阅读(155) 评论(0) 推荐(0) 编辑
摘要: AOF 持久化功能的实现可以分为命令追加(append)、文件写入、文件同步(sync)三个步骤。 命令追加 当 AOF 持久化功能处于打开状态时, 服务器在执行完一个写命令之后, 会以协议格式将被执行的写命令追加到服务器状态的 aof_buf 缓冲区的末尾: struct redisServer 阅读全文
posted @ 2020-12-24 15:06 Tracydzf 阅读(81) 评论(0) 推荐(0) 编辑
摘要: 假如我们要用某种数据结构来维护一组有序的int型数据的集合,并且希望这个数据结构在插入、删除、查找等操作上能够尽可能着快速,那么,你会用什么样的数据结构呢? 数组 一种很简单的方法应该就是采用数组了,在查找方面,用数组存储的话,采用二分法可以在 O(logn) 的时间里找到指定的元素,不过数组在插入 阅读全文
posted @ 2020-12-24 14:15 Tracydzf 阅读(69) 评论(0) 推荐(0) 编辑
摘要: 图 IMAGE_RDB_STRUCT_OVERVIEW 展示了一个完整 RDB 文件所包含的各个部分。 注意 为了方便区分变量、数据、常量, 图 IMAGE_RDB_STRUCT_OVERVIEW 中用全大写单词标示常量, 用全小写单词标示变量和数据。 本章展示的所有 RDB 文件结构图都遵循这一规 阅读全文
posted @ 2020-12-24 10:37 Tracydzf 阅读(143) 评论(0) 推荐(0) 编辑
摘要: Redis 是一个键值对(key-value pair)数据库服务器, 服务器中的每个数据库都由一个 redis.h/redisDb 结构表示, 其中, redisDb 结构的dict 字典保存了数据库中的所有键值对, 我们将这个字典称为键空间(key space): typedef struct 阅读全文
posted @ 2020-12-23 17:54 Tracydzf 阅读(153) 评论(0) 推荐(0) 编辑
摘要: 除了前面介绍过的 type 、 encoding 、 ptr 和 refcount 四个属性之外, redisObject 结构包含的最后一个属性为 lru 属性, 该属性记录了对象最后一次被命令程序访问的时间: typedef struct redisObject { // ... unsigne 阅读全文
posted @ 2020-12-23 16:30 Tracydzf 阅读(205) 评论(0) 推荐(0) 编辑
摘要: 因为 C 语言并不具备自动的内存回收功能, 所以 Redis 在自己的对象系统中构建了一个引用计数(reference counting)技术实现的内存回收机制, 通过这一机制, 程序可以通过跟踪对象的引用计数信息, 在适当的时候自动释放对象并进行内存回收。 每个对象的引用计数信息由 redisOb 阅读全文
posted @ 2020-12-23 14:29 Tracydzf 阅读(71) 评论(0) 推荐(0) 编辑
摘要: Redis 中用于操作键的命令基本上可以分为两种类型。 其中一种命令可以对任何类型的键执行, 比如说 DEL 命令、 EXPIRE 命令、 RENAME 命令、 TYPE 命令、 OBJECT 命令, 等等。 举个例子, 以下代码就展示了使用 DEL 命令来删除三种不同类型的键: # 字符串键 re 阅读全文
posted @ 2020-12-23 14:19 Tracydzf 阅读(114) 评论(0) 推荐(0) 编辑
摘要: 有序集合的编码可以是 ziplist 或者 skiplist 。 ziplist 编码的有序集合对象使用压缩列表作为底层实现, 每个集合元素使用两个紧挨在一起的压缩列表节点来保存, 第一个节点保存元素的成员(member), 而第二个元素则保存元素的分值(score)。 压缩列表内的集合元素按分值从 阅读全文
posted @ 2020-12-23 11:03 Tracydzf 阅读(77) 评论(0) 推荐(0) 编辑
摘要: 集合对象的编码可以是 intset 或者 hashtable 。 intset 编码的集合对象使用整数集合作为底层实现, 集合对象包含的所有元素都被保存在整数集合里面。 举个例子, 以下代码将创建一个如图 8-12 所示的 intset 编码集合对象: redis> SADD numbers 1 3 阅读全文
posted @ 2020-12-23 09:51 Tracydzf 阅读(86) 评论(0) 推荐(0) 编辑
上一页 1 ··· 12 13 14 15 16 17 18 19 20 ··· 39 下一页