因为Redis服务器将数据存储在内存里面,而一旦服务器被关闭或者运行服务器的主机本身被关闭的话,存储在内存里面的数据就会消失不见;

如果我们仅仅是将redis用作缓存的话,那么这种数据丢失带来的问题并不是非常大,我们只需要重启机器,然后再次将数据放到缓存里面就可以了;

但如果我们将redis用作数据库的话,那么这种数据丢失就不能接受了。

一、RDB持久化原理

将服务器包含的所有数据库数据以二进制文件的形式保存到硬盘里面。

通过在服务器启动时载入RDB文件,服务器可以根据RDB文件的内容,还原服务器原有的数据库数据。

二、创建RDB文件
Redis服务器在什么时候创建RDB文件?
1) 服务器执行客户端发送的SAVE命令;(手动执行)
2) 服务器执行客户端发送的BGSAVE命令;(手动执行)
3) 使用save配置选项设置的自动保存条件被满足,服务器自动执行BGSAVE命令;(自动执行)

2.1 手动创建RDB文件之SAVE命令

通过使用客户端向服务器发送SAVE命令,可以命令服务器去创建一个新的RDB文件;

redis> SAVE
OK

在执行SAVE命令时过程中(也就是创建RDB文件的过程中),redis服务器将被阻塞,无法处理客户端发送的命令请求,只有在SAVE命令执行完毕后(也就是RDB文件创建完毕之后),服务器才会重新开始处理客户端发送的命令请求;如果RDB文件已经存在,那么服务器将使用新的RDB文件去替代旧的RDB文件。

SAVE命令的复杂度为O(N),N为服务器中所有数据库包含的键值对数量总和。

2.2手动创建RDB文件之BGSAVE命令

BGSAVE命令同样可以创建一个新的RDB文件,这个命令和SAVE命令的区别在于:BGSAVE不会造成redis服务器阻塞,在执行BGSAVE命令的过程中,redis服务器 仍然可以正常地处理其他客户端发送的命令请求。

BGSAVE是一个异步命令,发送命令的客户端立即得到回复,而实际的操作是在回复之后才开始;

redis> BGSAVE
Background saving started

BGSAVE命令的复杂度和SAVE一样,都是O(N),N为服务器中所有数据库包含的键值对数量总和。

BGSAVE不会造成阻塞的原因:
1) 当redis服务器 接收到BGSAVE命令时,它不会自己来创建RDB文件,而是通过fork()来生成一个子进程,然后由子进程负责创建RDB文件,而自己则继续处理客户端的命令请求;
2) 当子进程创建好RDB文件并退出时,它会向父进程(也就是负责处理命令请求的redis服务器)发送一个信号,告知它RDB文件已经创建完毕;
3) 最后redis服务器(父进程)接收到子进程创建的RDB文件,BGSAVE执行完毕;

BGSAVE执行过程:

SAVE和BGSAVE对比

注意:两者并没有谁好谁坏之分,各自适用于不同的场景。

2.3 自动创建RDB文件

以上介绍的SAVE和BGSAVE均需要手工介入。Redis服务器提供了自动进行RDB持久化操作,redis提供了save配置选项,通过这个选项,用户可以设置任意多个保存条件,每当保存条件中的任意一个被满足时,服务器就会自动执行BGSAVE命令。
save选项的格式:

save <seconds> <changes>

描述:如果距离上一次创建RDB文件已经过去seconds秒,并且服务器的所有数据库总共已经发生了不少于changes次修改(添加/删除/更新),那么执行BGSAVE。

示例:

save  

表示距离上一次创建RDB文件已经过去了300秒,并且服务器的所有数据库总共发生了不少于10次修改,那么执行BGSAVE命令;

save  

表示距离上一次创建RDB文件已经过去了60秒,并且服务器的所有数据库总共发生了不少于10000次修改,那么执行BGSAVE命令;

save
save
save

主要三个条件中的任意一个满足时,redis服务器就自动执行BGSAVE命令。

每次创建RDB文件之后,服务器为实现自动持久化而设置的时间计数器和次数计数器就会被清零,并重新开始计数,所以所个保存条件的效果是不会叠加的

Redis数据持久化之RDB持久化的更多相关文章

  1. 使用AOF持久化文件实现还原Redis数据库并得到RDB持久化文件

    目录 1 编写本文的初衷 2 具体实施 2.1 Redis持久化概念简介 2.2 获取指定Redis的AOF持久化文件 2.3 把Redis的持久化AOF文件转换为RDB文件 1 编写本文的初衷 因为 ...

  2. Redis 详解 (六) RDB 持久化

    目录 1.RDB 简介 2.触发方式 ①.自动触发 ②.手动触发 3.恢复数据 4.停止 RDB 持久化 5.RDB 的优势和劣势 6.RDB 自动保存的原理  前面我们说过,Redis 相对于 Me ...

  3. [Redis] redis数据备份恢复与持久化

    数据库备份,使用save命令,将会在redis的安装目录中生成dump.rdb 例如:在我的目录下 redis/src/dump.rdb 使用命令config get dir,获取当前redis的安装 ...

  4. Redis数据持久化、数据备份、数据的故障恢复

    1.redis持久化的意义----redis故障恢复 在实际的生产环境中,很可能会遇到redis突然挂掉的情况,比如redis的进程死掉了.电缆被施工队挖了(支付宝例子)等等,总之一定会遇到各种奇葩的 ...

  5. Redis持久化之RDB&&AOF的区别

    在说Redis持久化之前,需要搞明白什么是数据库状态这个概念,因为持久化的就是将内存中的数据库状态保存到磁盘上.那么什么是数据库状态呢?Redis是一个key-value数据库服务器,一般默认是有16 ...

  6. 【Redis】Redis学习(七) Redis 持久化之RDB和AOF

    Redis 持久化提供了多种不同级别的持久化方式:一种是RDB,另一种是AOF. RDB 持久化可以在指定的时间间隔内生成数据集的时间点快照(point-in-time snapshot). AOF ...

  7. redis——持久化方式RDB与AOF分析

    https://blog.csdn.net/u014229282/article/details/81121214 redis两种持久化的方式 RDB持久化可以在指定的时间间隔内生成数据集的时间点快照 ...

  8. redis系列:RDB持久化与AOF持久化

    前言 什么是持久化? 持久化(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘).持久化的主要应用是将内存中的对象存储在数据库中,或者存储在磁盘文件中.XML数 ...

  9. Redis实现之RDB持久化(一)

    RDB持久化 Redis是一个键值对数据库服务器,服务器中通常包含着任意个非空数据库,而每个非空数据库中又可以包含任意个键值对,为了方便起见,我们将服务器中的非空数据库以及它们的键值对统称为数据库状态 ...

随机推荐

  1. linux下openoffice的安装和启动

    下载openoffice的安装包(注意选择合适的安装包): http://www.openoffice.org/download/archive.html 一.安装openOffice1.使用tar ...

  2. session.flush加锁测试.

    测试结论 1 session.flush (用于提交SQL执行计划. hibernate会给数据库加锁, 执行效果等同于select for update的锁级别.如果是oracle 默认为lock ...

  3. bzoj2467: [中山市选2010]生成树

    Description 有一种图形叫做五角形圈.一个五角形圈的中心有1个由n个顶点和n条边组成的圈.在中心的这个n边圈的每一条边同时也是某一个五角形的一条边,一共有n个不同的五角形.这些五角形只在五角 ...

  4. Linux下nl命令的用法详解

    Linux中nl命令和cat命令很像,不过nl命令会打上行号,属于比较不常用的命令,下面随小编一起来了解下这个鲜为人知的nl命令吧. nl命令在linux系统中用来计算文件中行号.nl 可以将输出的文 ...

  5. GCC 编译使用动态链接库和静态链接库

    1 库的分类 根据链接时期的不同,库又有静态库和动态库之分. 静态库是在链接阶段被链接的(好像是废话,但事实就是这样),所以生成的可执行文件就不受库的影响了,即使库被删除了,程序依然可以成功运行. 有 ...

  6. [系统开发] Bind DNS 管理系统

    一.问题的产生 很多公司的 DNS 是用 BIND 建立的:DNS 服务非常重要,BIND 功能虽然强大,但是是基于配置文件进行管理的,管理员对 DNS 进行的任何操作都要通过修改配置文件来实现,稍不 ...

  7. 黄聪:WordPress 多站点建站教程(五):获取子站点用户信息(通过输入站点ID号来获取该站点的所有用户)

    得到站点ID为1的用户 <ul> <?php $blogusers = get_users('blog_id=1'); foreach ($blogusers as $user) { ...

  8. windows7修改双系统启动项名称、先后顺序、等待时间

    一.进入BCDEdit.exe  正常启动Windows 7 系统,点击“开始” -> “所有程序” -> “附件”,右击“命令提示符” -> “以管理员身份运行”(需要将操作当前用 ...

  9. solr基于jetty容器配置后台登陆角色用户名密码

    solr版本4.0.0 我的solr下载后解压在d盘,你的随意. 在D:\apache-solr-4.0.0\apache-solr-4.0.0\example\etc目录下新建role.proper ...

  10. PO_PO系列 - 询价报价单管理分析(案例)

    2014-07-01 Created By BaoXinjian