Redis(五)--- Redis的持久化RDB与AOF
一、Redis数据库
我们都知道Redis是基于内存的数据库,数据是以key-value键值对的方式存储的,那么key-value键值对是随意放在内存中的么,其实Redis的服务会创建很多的数据库空间,这些key-value键值对都是在各个数据库空间中存储的。
当我们使用客户端工具链接Redis服务时,会在客户端中看到一系列的db*命名的项(如图),这些就是一个个数据库,Redis初始化创建16个数据库,数据库创建个数可以在配置文件中修改。
而在命令行模式中是看不到这些数据库的具体数量的,但在命令行提示符的右侧会提示我们当前处于哪个数据库(如图),并且可以用上一章说到的SELECT命令进行数据库的切换;客户端默认连接第一个数据库,即0号数据库。
(1)数据库键空间
key-value键值对存储在各个数据库中,而每个数据库内部都是由一个redisDb结构,结构中有若干个属性,最主要的有两个属性dict、expires。
typedef struct redisDb {
// ...
// 数据库键空间,保存着数据库中的所有键值对
dict *dict; // 过期字典,保存着键的过期时间
dict *expires;
// ...
} redisDb;
- dict 是字典结构,存储我们的key-value键值对,这个字典称为数据库键空间,字典的键就是数据库的键,每个键都是一个字符串,存储key值;字典的值就是数据库的值,每个值都可以是五大对象中任意一种,存储value值;所以我们存储的key-value最终是在数据库中以字典的结构存储的。
- expires 同样是字典结构,但其存储的是key-value过期时间;当我们设置了key-value的过期时间,那么key-value存储在dict字典中,而过期时间则存储在expires中;字典的键存储key,字典的值存储过期时间;这里需要注意的是,无论设置的过期时间是秒还是毫秒,最终存储时都会转换为unix毫秒时间戳。
图中是带有过期字典的数据库例子
(2)持久化
上面说道的无论是数据库还是期内的数据都是存储在服务器内内存中的,如果服务器一旦发生掉电,进程退出等情况,那么其内存中的数据就都消失不见了,在我们大规模并发的项目下,显然这是灾难性的,所以应对这种情况的办法之一,就是持久化,把内存中的数放到磁盘中,意外发生后,能够从磁盘上进行数据恢复到内存中,这样就避免了数据丢失。
Redis提供了两种持久化方式RDB持久化和AOF持久化。
2、RDB持久化
RDB持久化是最直接的持久化方式,直接将内存中的数据保存到RDB文件中,当恢复时也是直接从RDB文件中恢复;
- RDB文件是经过压缩的二进制文件,这里对文件结构不做详解。
- RDB持久化可以手动执行,也可以设置定期执行。
- RDB持久化命令有两个SAVE(同步)和BGSAVE(异步),同步持久化过程中,会拒绝客户端的所有请求;异步则是创建子进程执行,不会对客户端产生影响,具体可以看上一章的命令介绍。
自动间隔性保存
因为BGSAVE命令是异步执行,不会阻塞服务器,所以Redis允许用户自行配置SAVE选项,当选项触发时自动执行BGSAVE命令。
当用户开启了触发自动BGSAVE后,如果不配置save选项,服务器会使用默认设置,如下:
(1)在900秒内,对数据库进行了至少1次修改。
(2)在300秒内,对数据库进行了至少10次修改。
(3)在60秒内,对数据库进行了至少10000次修改。
以上三个条件,满足任意一条,就会进行BGSAVE操作
3、AOF持久化
AOF持久化与RDB不同,AOF持久化是通过记录服务器所执行的命令来保存数据的。
- 被写入AOF文件的所有命令都是以Redis请求协议格式保存的。
- 数据的还原,就是通过读取AOF文件的这些命令进行的。
- 执行的命名并不是直接写入AOF文件的,而是先写入缓冲区,没执行一条命令就会追加到缓冲区的末尾,当一条命令执行完成后,返回数据前,会将缓冲区的数据写入到AOF文件中。
AOF文件的载入与还原
AOF持久化的数据还原过程就是读取AOF中命令重新执行命令的过程。
(1)Redis会创建一个伪客户端,伪客户端与真实的客户端执行命令的效果是一样的,只是不带网络连接。
(2)从AOF文件分析并读取一条命令。
(3)伪客户端执行这条命令。
(4)重复2和3过程,知道AOF文件中的所有命令处理完成。
AOF文件重写
AOF文件的持久化是记录被执行对的命令,这样随着时间越来越长,AOF文件中的内容会越来越多,体积也会越来越大,文件越大恢复数据的时间也越多。
在命令执行的过程中有些键值对被删除了,有些被修改了,而这些过程命令是完全没有必要再执行一遍的,所以Redis提供了AOF文件的重写功能对AOF进行重建,使用重建后的文件要比元AOF文件体积小很多。
- AOF文件重写,并不需要对原AOF文件进行任何访问改动,他是通过对数据库内的数据读取来操作的,即查看数据库内有什么数据,然后根据数据类型进行创建这些数据的写入命令。
- AOF文件重写过程中,创建写入命令时会先检查元素数量,如果数量超过了redis.h/REDIS_AOF_REWRITE_ITEMS_PER_CMD=64常量的值,就会分成多条命令,
- AOF文件重写是有子进程进行的,并不影响主进程处理命令;子进程而不是线程,因为进程带有数据副本,不锁数据的情况下,能保证安全。
- AOF文件子进程重写过程中,主进程仍然在处理数据,这样造成了子进程和主进程的数据不一致,子进程数据少了一部分,这种情况下Redis会创建一个AOF重写缓冲区;这样少的那部分命令会写到AOF重写缓冲区中,重写完成后,再把缓冲区这些命令写进新的AOF文件中,然后用新的AOF文件替换就得AOF文件。
4、总结
- Redis初始化会创建一批数据库,每个数据库的内部数据结构都是字典,key-value的最终存储也会落到字典上。
- AOF持久化比RDB持久化频率更高、速度更快;当有AOF持久化时,RDB持久化命令不会再执行;但当RDB持久化命令执行时,AOF命令会等待其执行完成后再执行,而其他RDB命令不会执行。
- AOF文件重写过程不会影响旧的AOF文件,即便AOF重写过程失败,也不会干扰原来的AOF恢复数据,只有在成功之后才会替换原来的文件。
参考:
《Redis设计与实现》黄健宏著,网上对Redis的详解等
此博客为笔者使用redis很久之后,参考网络上各类文章总结性书写,原创手打,如有错误欢迎指正。
Redis(五)--- Redis的持久化RDB与AOF的更多相关文章
- redis++:Redis的两种持久化 RDB 和 AOF
Redis持久化备份数据的方式有两种:RDB(Redis DataBase) . AOF(Append Only File). RDB 什么是RDB: 在指定时间间隔内,将内存中的数据集快照写入磁盘 ...
- Redis(二)、Redis持久化RDB和AOF
一.Redis两种持久化方式 对Redis而言,其数据是保存在内存中的,一旦机器宕机,内存中的数据会丢失,因此需要将数据异步持久化到硬盘中保存.这样,即使机器宕机,数据能从硬盘中恢复. 常见的数据持久 ...
- Redis之数据持久化RDB与AOF
Redis之数据持久化RDB与AOF https://www.cnblogs.com/zackku/p/10087701.html 大家都知道,Redis之所以性能好,读写快,是因为Redis是一个内 ...
- Linux - redis持久化RDB与AOF
目录 Linux - redis持久化RDB与AOF RDB持久化 redis持久化之AOF redis不重启,切换RDB备份到AOF备份 确保redis版本在2.2以上 实验环境准备 备份这个rdb ...
- redis持久化 RDB与AOF
redis持久化 RDB与AOF RDB与AOF区别 rdb: 基于快照的持久化,速度更快,一般用做备份,主从复制也是依赖于rdb持久化功能 aof:以追加的方式记录redis操作日志的文件,可以最大 ...
- Redis持久化RDB、AOF
持久化的意思就是保存,保存到硬盘.第一次接触这个词是在几年前学习EF. 为什么要持久化 redis定义:Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代 ...
- Redis 持久化 rdb、Aof对比
一.Redis 简介: Redis是一个开源的.基于内存的数据结构存储器,可以用作数据库.缓存和消息中间件. Redis是一个key-value存储系统.和Memcached类似,它支持存储的valu ...
- redis基础:redis下载安装与配置,redis数据类型使用,redis常用指令,jedis使用,RDB和AOF持久化
知识点梳理 课堂讲义 课程计划 1. REDIS 入 门 (了解) (操作) 2. 数据类型 (重点) (操作) (理解) 3. 常用指令 (操作) 4. Jedis (重点) (操作) ...
- Redis持久化----RDB和AOF 的区别
关于Redis说点什么,目前都是使用Redis作为数据缓存,缓存的目标主要是那些需要经常访问的数据,或计算复杂而耗时的数据.缓存的效果就是减少了数据库读的次数,减少了复杂数据的计算次数,从而提高了服务 ...
随机推荐
- 通过OSG实现对模型的日照模拟
目录 1. 加载模型 2. 光照 1) 环境反射 2) 漫反射 3) 日照方向 (1) 太阳高度角和太阳方位角 (2) 计算过程 4) 改进实现 3. 阴影 4. 太阳高度角与太阳方位角的计算 1) ...
- Python连载7-time包的其他函数
接连载6 一.time包 1.函数:sleep(second) (1)含义:是程序进入休眠状态多少秒 (2)格式:time.sleep(int num) 2.函数:strftime() (1)含义:将 ...
- kafka 0.11.0.3 源码编译
首先下载 kafka 0.11.0.3 版本 源码: http://mirrors.hust.edu.cn/apache/kafka/0.11.0.3/ 下载源码 首先安装 gradle,不再说明 1 ...
- awk数组统计
处理以下文件内容,将域名取出并根据域名进行计数排序处理:(百度和sohu面试题) http://www.etiantian.org/index.html http://www.etiantian.or ...
- 美好生活从java开始
小编将会在接下来的日子里不断更新.分享一些IT方面的技术,以及自己的一些心得体会,希望大家能在我这有所收获.有所成长,那么我们就从java开始. 我们要想学习一样东西并且学好它,首先我们要弄清楚我们将 ...
- Kali Linux Web渗透测试手册(第二版) - 1.1 - Firefox浏览器下安装一些常用的插件
一.配置KALI Linux和渗透测试环境 在这一章,我们将覆盖以下内容: l 在Windows和Linux上安装VirtualBox l 创建一个Kali Linux虚拟机 l 更新和升级Ka ...
- Appium+python自动化(十三)- 与Capability完美懈垢之解读(超详解)
简介 Capability又叫Appium Desired Capabilities,前边写了那么多实例代码,小伙伴可以发现一些规律,就是有一部分代码总是重复的出现在你的视线中.这部分就是对Capab ...
- ASP.Net Core2.1 秒杀项目一步一步实现CI/CD系列一
前言:有一段时间没写博客了,那是因为博主菜,需要学习和准备,这不带来了本系列的文章.在这里我把学习的心得分享出来,有些点理解的也不是太到位,希望大佬们能多多给点建议和指导.下半年就把这个系列的文章写完 ...
- 50道SQL练习题及答案与详细分析!!!
以前在学校还没有很认真地意识到,现在到了企业才发现sql是那么的重要,看到网上有很多的sql 练习题,特地拿来练练手! 数据表介绍 --1.学生表 Student(SId,Sname,Sage,Sse ...
- golang开发:类库篇(二) Redis连接池的使用
为什么要使用连接池 一个数据库服务器只拥有有限的连接资源,一旦所有的连接资源都在使用,那么其它需要连接的资源就只能等待释放连接资源.所以,在连接资源有限的情况下,提高单位时间的连接的使用效率,缩短连接 ...