关注我,能够获取最新知识、经典面试题以及微服务技术分享面试
持久化(Persistence),持久化是将程序数据在持久状态和瞬时状态间转换的机制,即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。redis
redis为内存数据库,为了防止服务器宕机以及服务器进程退出后,服务器数据丢失,Redis提供了持久化功能,即将Redis中内存数据持久化到磁盘中。Redis 提供了不一样级别的持久化方式:数据库
若是服务器开启了AOF持久化功能。服务器会优先使用AOF文件还原数据。只有关闭了AOF持久化功能,服务器才会使用RDB文件还原数据segmentfault
RDB文件是一个通过压缩的二进制文件(默认的文件名:dump.rdb),由多个部分组成,RDB格式:安全
在 Redis持久化时, RDB 程序将当前内存中的数据库状态保存到磁盘文件中, 在 Redis 重启动时, RDB 程序能够经过载入 RDB 文件来还原数据库的状态。服务器
当 Redis 须要保存 dump.rdb 文件时, 服务器执行如下操做:app
这种工做方式使得 Redis 能够从写时复制(copy-on-write)机制中获益。异步
SAVE 函数
同步操做,在执行该命令时,服务器会被阻塞,拒绝客户端发送的命令请求微服务
redis> save
BGSAVE
异步操做,在执行该命令时,子进程执行保存工做,服务器还能够继续让主线程处理客户端发送的命令请求
redis>bgsave
自动建立
因为BGSAVE命令可不阻塞服务器进程下执行,可让用户自定义save属性,让服务器每一个一段时间自动执行一次BGSAVE命令(即经过配置文件对 Redis 进行设置, 让它在“ N 秒内数据集至少有 M 个改动”这一条件被知足时, 自动进行数据集保存操做)。
好比: /*服务器在900秒以内,对数据库进行了至少1次修改*/ Save 900 1 /*服务器在300秒以内,对数据库进行了至少10次修改*/ Save 300 10 /*服务器在60秒以内,对数据库进行了至少10000次修改*/ Save 60 10000
只要知足其中一个条件就会执行BGSAVE命令
################################ SNAPSHOTTING ################################ # # Save the DB on disk: #在给定的秒数和给定的对数据库的写操做数下,自动持久化操做。 # save <seconds> <changes> # save 900 1 save 300 10 save 60 10000 #bgsave发生错误时是否中止写入,通常为yes stop-writes-on-bgsave-error yes #持久化时是否使用LZF压缩字符串对象? rdbcompression yes #是否对rdb文件进行校验和检验,一般为yes rdbchecksum yes # RDB持久化文件名 dbfilename dump.rdb #持久化文件存储目录 dir ./
AOF持久化是经过保存Redis服务器所执行的写命令来记录数据库状态
AOF持久化功能实现:
append命令追加:当AOF持久化功能处于打开状态时,服务器执行完一个写命令会协议格式被执行的命令追加服务器状态的aof_buf缓冲区的末尾。
reids>SET KET VAULE //协议格式 \r\n$3\r\nSET\r\n$3\r\nKEY\r\n$5\r\nVAULE\r\n
redis> SET msg "Ccww" redis> SADD persistence "rdb" "aof" redis> RPUSH size 128 256 512
AOF持久化策略(即缓冲区内容写入和同步sync到AOF中),能够经过配置appendfsync属性来选择AOF持久化策略:
AOF持久化策略的效率与安全性:
因为AOF持久化会把执行的写命令追加到AOF文件中,因此随着时间写入命令会不断增长, AOF文件的体积也会变得愈来愈大。AOF文件体积大对Reids服务器,甚至宿主服务器形成影响。
为了解决AOF文件体积膨胀的问题,Redis提供了AOF文件重写(rewrite)功能:
auto-aof-rewrite-percentage
(触发AOF文件执行重写的增加率) 以及 auto-aof-rewrite-min-size
(触发AOF文件执行重写的最小尺寸) AOF重写的做用:
Redis服务器使用单个线程来处理命令请求,服务器大量调用aof_rewrite函数,在AOF重写期间,则没法处理client发来的命令请求,因此AOF重写程序放在子进程执行,好处:
AOF重写使用子进程会形成数据库与重写后的AOF保存的数据不一致,为了解决这种数据不一致,redis使用了AOF重写缓冲区
实现:
BGREWRITEAOF命令实现原理(只有信号处理函数执行时才对服务器进程形成阻塞):
############################## APPEND ONLY MODE ############################### #开启AOF持久化方式 appendonly no #AOF持久化文件名 appendfilename "appendonly.aof" #每秒把缓冲区的数据fsync到磁盘 appendfsync everysec # appendfsync no #是否在执行重写时不一样步数据到AOF文件 no-appendfsync-on-rewrite no # 触发AOF文件执行重写的增加率 auto-aof-rewrite-percentage 100 #触发AOF文件执行重写的最小size auto-aof-rewrite-min-size 64mb #redis在恢复时,会忽略最后一条可能存在问题的指令 aof-load-truncated yes #是否打开混合开关 aof-use-rdb-preamble yes
RDB的优势
RDB的缺点
AOF的优势:
AOF 缺点:
通常来讲, 若是想达到足以媲美 PostgreSQL 的数据安全性, 你应该同时使用两种持久化功能。
若是你很是关心你的数据, 但仍然能够承受数分钟之内的数据丢失, 那么你能够只使用 RDB 持久化。
有不少用户都只使用 AOF 持久化, 但咱们并不推荐这种方式: 由于定时生成 RDB 快照(snapshot)很是便于进行数据库备份, 而且 RDB 恢复数据集的速度也要比 AOF 恢复的速度要快, 除此以外, 使用 RDB 还能够避免以前提到的 AOF 程序的 bug 。
最后可关注公众号【Ccww笔记】,一块儿学习。加群,天天会分享干货,还有学习视频领取!