redis之持久化(RDB、AOF)
文章目录
1Redis高可用
在Web服务器中, 高可用是指服务器可以正常访问的时间,衡量的标准是在多长时间内可以提供正常服务 (99.9%、99.99%、99.999%等等,表示单台服务器运行的不出错的概率)
但是在Redis中,高可用的含义似乎要广泛一些,除了保证提供正常服务(如主从复制,快速容灾技术),还需要考虑数据容量的扩展,数据安全不会丢失等。
在Redis中,实现高可用的技术主要包括持久化、主从复制、哨兵和集群。
持久化: 持久化最简单的高可用方法(有时甚至不被归为高可用的手段),主要作用是数据备份,即将数据存储在硬盘,保证数据不会因进程退出而丢失。
主从复制: 主从复制是高可用Redis的基础,哨兵和集群都是在主从复制基础上实现高可用的。主从复制主要实现了数据的多机备份,以及对于读操作的负载均衡和简单的故障恢复。 缺陷:故障恢复无法自动化;写操作无法负载均衡;存储能力受到单机的限制。
哨兵: 在主从复制的基础上, 哨兵实现了自动化的故障恢复 。缺陷 :写操作无法负载均衡;存储能力受到单机的限制。
集群: 通过集群, Redis解决了写操作无法负载均衡,以及存储能力受到单机限制的问题,实现了较为完善 的高可用方案。
2Redis持久化
2.1持久化的功能
Redis是内存数据库,数据都是存储在内存中 ,为了避免服务器断电等原因导致Redis进程异常退出后数据的永久丢失,需要定期将Redis中的数据以某种形式(数据或命令)从内存保存到硬盘;当下次Redis重启时,利用持久化文件实现数据恢复。除此之外,为了进行灾难备份,可以将持久化文件拷贝到一个远程位置。
2.2Redis的两种持久化
RDB持久化(Redis DataBase): 原理是将Redis在内存中的数据库记录定时保存到磁盘上。(类似快照)。
AOF持久化(Append Only File): 原理是将Redis的操作日志以追加的方式写入文件。(类似于Mysql的binlog)
总结:由于AOF持久化的实时性更好,即当进程意外退出时丢失的数据更少,因此AOF是目前主流的持久化方式。
3Redis的RDB持久化
RDB持久化是指在指定的时间间隔内将内存中当前进程中的数据生成快照保存到硬盘(因此也称作快照持久化),用二进制压缩存储,保存的文件后缀是rdb;当Redis重新启动时,可以读取快照文件恢复数据。
3.1触发条件
触发条件有:手动触发和自动触发。
3.1.1手动触发
手动触发Redis进行RDB持久化的命令有两种:
①save命令
该命令会阻塞当前Redis服务器,执行save命令期间,Redis不能处理其他命令,直到RDB过程完成为止。
显然该命令对于内存比较大的实例会造成长时间阻塞,这是致命的缺陷,为了解决此问题,Redis提供了第二种方式。
②bgsave命令
执行该命令时 , Redis会在后台异步进行快照操作,快照同时还可以响应客户端请求 。具体操作是Redis进程执行fork操作创建子进程,RDB持久化过程由子进程负责,完成后自动结束。 阻塞只发生在fork阶段,一般时间很短。
3.1.2自动触发
在自动触发RDB持久化时,Redis也会选择bgsave而不是save来进行持久化
**-save:**这里是用来配置触发 Redis的 RDB 持久化条件,也就是什么时候将内存中的数据保存到硬盘。比如“save m n”。表示m秒内数据集存在n次修改时,自动触发bgsave。
当然如果你只是用Redis的缓存功能,不需要持久化,那么你可以注释掉所有