Redis——5、持久化RDB和AOF

一、Redis持久化的两种方法:

RDB(Redis DataBase Backup file)Redis数据备份文件 与AOF(Append Only File)追加文件

二、RDB

1、介绍

RDB 简单来说就是将物理内存中的数据快照写入磁盘中,当Redis实例宕机时,从磁盘读取RDB文件来恢复数据。

2、Redis操作命令

1)save 主进程执行RDB,会阻塞所有命令

2)bgsave fork一个子进程执行RDB,避免主进程受到阻塞

3)在redis.config条件执行RDB

save 900 1 (:指的是当900秒内有一个key被修改则执行RDB)

3、底层原理

页表:记录虚拟地址和物理地址的映射关系表

RDB的底层执行原理:当需要RDB时主进程会对物理内存中的数据进行写操作单Linux系统下的进程是不能直接访问物理内存 的,这个时候就会由操作系统分配给主进程一个页表 ,上面包含了虚拟地址和物理地址的映射关系,当我们修改虚拟地址的数据时对应的物理地址的数据也会由于映射而改变,可如果只用主进程来执行RDB的话,会阻塞主进程的所有命令,所以我们通常采用bgsave来开启一个子进程执行RDB,开启子进程就是将主进程的页表复制给子进程, 这时主进程和子进程会实现数据的共享,可以同时读数据并将内存数据持久化到磁盘当中且不影响主进程命令的执行,但如果子进程进行读数据的同时主进程进行写数据,那么持久化就会出现脏数据,解决办法是在fork中会采用copy-on-write技术当主进程进行写操作的时候会把内存中对应的数据复制一份至内存中新的地址然后进行页表的更新以及写操作即可,再次进行RDB时子进程就能读取到最新数据了。

三、AOF

1、介绍

AOF简单来说就是将每次的Redis命令记录到AOF文件中,相当于日志记录,当Redis实例宕机时,从磁盘读取AOF文件重新执行一次AOF中命令即可恢复数据,数据完整性较高,刷盘策略决定了AOF文件更新的频率

2、Redis操作命令

1)AOF在Redis中默认是关闭的,需要在redis.config中手动开启

#默认为no 开启为yes

appendonly yes;

#AOF文件命名

appendfilename "name.aof"

2)三种刷盘策略:

apeendfsync Always 同步刷盘

appendfsync everysec 每秒刷盘

appendfsync no 操作系统控制

3)bgrewriteof

如果AOF文件中的命令有两个或多个是针对同一个key进行写操作的,但只有最后一次写命令会实际生效,这样会造成很大的命令冗余,这时我们可以用bgrewriteof来对AOF文件进行命令重写,去除那些冗余的命令。

示例:

原AOF文件

set num 123

set name john

ser num 456

重写后AOF文件

mset name john num 456

我们可以在redis.config中设置重写条件

#指的是当AOF文件大于原来的150%时进行bgrewrite文件重写

auto-aof-rewrite-percentage 150

#指的是当AOF文件最小多大以上才触发重写

auto-aof-rewrite-min-size 64mb

相关推荐
1892280486112 分钟前
NW622NW623美光固态闪存NW624NW635
大数据·网络·数据库·人工智能·microsoft·性能优化
云飞云共享云桌面22 分钟前
1台电脑10个画图设计用怎么实现
linux·运维·服务器·网络·数据库·自动化·电脑
TTBIGDATA1 小时前
【Ambari监控】Ambari-Metrics 的分支研究
大数据·数据库·hadoop·ambari·bigtop·edp·hidataplus
Z_z在努力1 小时前
【杂类】应对 MySQL 处理短时间高并发的请求:缓存预热
数据库·mysql·缓存
lifallen1 小时前
揭秘KafkaStreams 线程缓存:NamedCache深度解析
数据结构·算法·缓存·kafka·apache
望获linux2 小时前
【实时Linux实战系列】规避缺页中断:mlock/hugetlb 与页面预热
java·linux·服务器·数据库·chrome·算法
longerxin20202 小时前
MongoDB 在线安装-一键安装脚本(CentOS 7.9)
数据库·mongodb·centos
失散132 小时前
分布式专题——9 Redis7底层数据结构解析
java·数据结构·redis·分布式·缓存·架构
2501_915921432 小时前
iOS 文件管理与能耗调试结合实战 如何查看缓存文件、优化电池消耗、分析App使用记录(uni-app开发与性能优化必备指南)
android·ios·缓存·小程序·uni-app·iphone·webview
程序员TNT2 小时前
Shoptnt 安全架构揭秘:JWT 认证与分布式实时踢人方案
java·redis·分布式·架构