zoukankan      html  css  js  c++  java
  • Redis简明教程:持久化

    Redis简明教程:持久化

    RDB持久化

      我们都知道Redis内存数据库,所以当一些意外发生,比如进程被终止、服务器宕机等等,Redis中存储的这些数据也都会随之消失。为了解决这个问题,Redis提供了RDB持久化功能。RDB持久化功能生成的RDB文件是一个经过压缩的二进制文件,通过该二进制文件可以还原生成RDB文件时的数据状态!

      RDB可以将Redis在内存中的数据状态保存到磁盘里面,避免数据意外丢失!

      RDB可以手动执行,也可以定期执行,也可以将某个时间点的数据状态保存到一个RDB文件中!

      

    总之一句话,RDB技术将Redis数据库进行快照持久化到RDB文件,在任何时候都可以通过RDB文件进行数据库恢复

    创建和载入RDB文件

    创建RDB文件

      Redis有两个命令用于生成RDB文件,SAVEBGSAVE

    • SAVE命令会阻塞Redis服务器进程,直到RDB文件创建完成,期间,服务器不能处理任何命令请求。
    • BGSABE命令由子进程负责创建RDB文件,服务器进程继续处理命令请求。

      因为BGSAVE命令可以在不阻塞服务器进程的情况下执行,所以我们可以通过设置服务器配置的save选项,让服务器在条件满足的情况下自动执行,举个例子:

    save 900 1  //900秒内,至少对数据库进行1次修改
    save 300 10 //300秒内,至少对数据库进行10次修改
    save 60 10000 //60秒内,至少对数据库进行10000次修改
    

      只要满足以上三个条件的一种就会自动执行BGSAVE命令。

    载入RDB文件

      和保存不一样,RDB文件的载工作实在服务器启动时自动执行的,所以Redis并没有专门用于载入RDB文件的命令,只要Redis服务器启动时检测到RDB文件存在,他就会自动载入RDB文件

      以下是Redis服务器启动时打印的日志记录,其中第二条日志DB loaded from disk.....就是服务器在成功载入RDB文件之后打印的:

    AOF持久化

       除了RDB持久化方式外,Redis还提供了称之为AOF(Append Only File)的持久化功能。RDB会保存整个Redis的数据库快照,而AOF并不需要,它仅仅记录Redis服务器所有的写命令来记录数据库状态

      相当于AOF把你的操作记录下来写个操作手册,当需要恢复的时候,按照操作手册做一遍就完事了!。

        

    AOF文件重写

      因为AOF持久化是保存被执行的写命令来记录数据库状态的,所以随着服务器运行时间的流逝,AOF文件中的内容会越来越多,体积不断膨胀。为此Redis提供了称之为重写的功能,通过创建一个新的AOF文件来替代现有的AOF文件,新旧两个AOF文件所保存的数据库状态相同,但是新AOF文件不会包含任何浪费空间的冗余命令,所以新的AOF文件的体积通常会比旧的AOF文件小很多

      其实原理也很简单,文件重写直接对数据库状态进行分析,生成最高效的写语句,而不用记录所有操作记录!

    参考资料

    • 《Redis设计与实现第二版》
  • 相关阅读:
    第四次上机作业
    第十一周作业
    Java第九次上机作业
    Java第八次上机作业
    Java第七次上机作业
    第八周作业
    Java第六次上机作业
    第七周作业
    Java第五次上机作业
    第六周作业
  • 原文地址:https://www.cnblogs.com/MrSaver/p/12199910.html
Copyright © 2011-2022 走看看