本篇文章带大家了解一下redis持久化中的aof,介绍一下aof原理、aof缺点,希望对大家有所帮助!
aof
上文我们提到了rredis中的一种持久化方式就是rdb此文我们来讲另一种实现方式那就是aof
aof是通过只记录redis写入命令的追加式日志文件
aof日志存储的因为是顺序指令,所以在redis宕机后,内部重走一遍老路,就可以达到恢复数据的目的
【相关推荐:redis视频教程】
aof原理每次我们执行写入命令的时候,redis都会把命令追加到aof文件里面实际是将内容写到内存的一个缓存汇总
所以redis需要实时的去调用linux提供的fsync函数每次将制定文件从内核缓存写到磁盘
因为如果实时的去调用函数是非常我们也可以通过改变配置参数来调整调用fsync函数的频率
重写如果一直追加aof文件,日志会变得越来越大所以redis内部实现了「重写」,用来压缩文件首先因为很多的key-value早就已经国企,或者很多值不断被更新,那么日志还存这些无用的数据显然是可以进行优化的所以创建一个子进程对内存进行遍历遍历成一个新的文件日志,所以实现了只有最新的值才需要存储在aof日志中我们可以使用下图的命令来开启重写,当然也可以设置成自动执行aof
aof缺点每次遍历整个内存,会给系统带来很大的额外性能开销
每次恢复数据是一个很长的过程并且每次进行从内核写到磁盘很耗费io性能
更多编程相关知识,请访问:编程入门!!
以上就是浅析redis中aof的原理和缺点的详细内容。