Redis-Redis的持久化(RDB/AOP)
2016-11-10 15:27
351 查看
由于Redis是基于内存的数据库,为了保证数据的可用性,Redis提供了两种数据持久化机制:RDB和AOP,下面对这两种持久化方式加以分析。
在执行fork函数的时候,操作系统会使用写时复制(copy-on-write)策略,也就是说在调用fork的一刻,父子进行有相同的内存模型,当父进程要修改其中的某片数据时,操作系统会将该片数据复制一份,从而保证不影响子进程。
rdb文件是经过压缩的文件,占用的空间比较小,更有利于传输,并且数据恢复速度也比较快。
2.rdb保存的是基于时间点的数据快照,更适合数据的备份和容灾
3.利用rdb文件进行数据恢复时,速度更快
2.当数据集非常大时,fork操作会占用很多系统资源,造成主服务进程假死
2.可容忍部分数据丢失
3.跨数据中心的容灾备份
aof机制默认关闭,可以通过
对于触发aof重写机制也可以通过配置文件来进行设置:
第一个参数是配置较前一个aof文件大小增长的百分比,第二个参数是配置触发aof重写的aof的最小的大小。
修改aof的fsync策略:
2.能够记录所有写操作,不会造成数据丢失
3.aof重写机制确保aof文件不会过大
4.aof文件可以很容易的读懂
2.在不同的fsync策略写,redis性能会受到一定影响
RDB
运行原理
RDB模式可以在指定的时间间隔内生成内存中整个数据集的持久化快照。快照文件默认被存储在当前文件夹中,名称为dump.rdb,可以通过dir和dbfilename参数来修改默认值。1.redis调用fork函数复制当前进行的一个副本-子进程 2.父进程继续接收并处理客户端发来的命令 3.子进行将内存中的数据写入一个临时的dump文件 4.子进程写入完成后,会用新的临时dump文件替换就的rdb文件 5.一次持久化完成
在执行fork函数的时候,操作系统会使用写时复制(copy-on-write)策略,也就是说在调用fork的一刻,父子进行有相同的内存模型,当父进程要修改其中的某片数据时,操作系统会将该片数据复制一份,从而保证不影响子进程。
rdb文件是经过压缩的文件,占用的空间比较小,更有利于传输,并且数据恢复速度也比较快。
RDB模式的优点
1.rdb持久化文件很紧凑,占用空间更小。2.rdb保存的是基于时间点的数据快照,更适合数据的备份和容灾
3.利用rdb文件进行数据恢复时,速度更快
RDB模式的缺点
1.会造成部分数据的丢失2.当数据集非常大时,fork操作会占用很多系统资源,造成主服务进程假死
RDB模式适用的场景
1.数据备份2.可容忍部分数据丢失
3.跨数据中心的容灾备份
AOF
aof持久化 记录服务器的所有写操作,并在服务器启动时重新执行这些命令来恢复数据集。aof文件中的命令全部以redis的协议格式存储,新命令会追加到文件的末尾,同时,redis还会在后台对aof文件进行重写,使得aof文件的体积不会过大。aof机制默认关闭,可以通过
appendonly = yes参数开启aof机制,通过
appendfilename = myaoffile.aof指定aof文件名称。
对于触发aof重写机制也可以通过配置文件来进行设置:
auto-aof-rewrite-percenttage = 100 auto-aof-rewrite-min-size 64mb
第一个参数是配置较前一个aof文件大小增长的百分比,第二个参数是配置触发aof重写的aof的最小的大小。
修改aof的fsync策略:
appendfsync=always 同步持久化每一次修改操作 appendfsync=everysec 每秒想aof文件同步一次 appendfsync=no 关闭向aof文件写入修改
aof的优点
1.支持不同的fsync策略:no/always/everysec2.能够记录所有写操作,不会造成数据丢失
3.aof重写机制确保aof文件不会过大
4.aof文件可以很容易的读懂
aof的缺点
1.虽然有aof重写机制,单aof文件通常比rdb文件大2.在不同的fsync策略写,redis性能会受到一定影响
相关文章推荐
- java鬼混笔记:redis 6、redis持久化:RDB与AOP配置
- redis(7)、redis持久化
- Redis持久化机制
- redis 两种持久化方式分析---rdb/aof
- spring boot 整合redis对查询数据做缓存( 利用spring的AOP技术)
- redis总结3-持久化rdb,aof,运维命令,Sentinel监控
- 对redis数据持久化的一些想法
- Redis持久化
- redis 持久化
- redis持久化
- Redis持久化 Snapshot和AOF说明
- Redis持久化实践及灾难恢复模拟
- redis持久化机制
- redis 事务,持久化,日志,主从,VM
- Redis学习手册(持久化)
- redis的持久化方式:RDB和AOF
- Redis之RDB持久化
- Redis 2种持久化模式的缺陷
- 分布式内存数据库---Redis的持久化
- redis---Redis持久化