Redis持久化
《Redis持久化》要点: redis是一种可内存也可持久化的内存数据库,所谓持久化,就是将数据放到断电后数据不会丢失的设备中,也就是通常理解的磁盘上. redis配置文件
redis持久化策略第一种:RDB快照 Redis支持将当前数据的快照存成一个数据文件的持久化机制.而一个持续写入的数据库如何生成快照呢?Redis借助fork命令的copy on write机制.在生成快照时,将当前进程fork出一个子进程,然后在子进程中循环所有的数据,将数据写成为RDB文件. 通过Redis的save指令来配置RDB快照生成规则,配置方式有两种; 一是配置Redis.conf 二是通过config set 命令在Redis运行时配置,不需重启Redis 查看save规则:
RDB文件写操作是在一个新进程中进行的,子进程会先将数据写入临时文件,然后通过原子性rename系统调用将临时文件重命名为RDB文件;当然,Redis的RDB文件也是Redis主从同步内部实现中的一环,使用od -c命令查看rdb文件内容,可以看到保存的实际是数据本身.
第二种:AOF日志 aof全称append only file,它是一个追加写入的日志文件.与一般数据库的binlog不同的是,AOF文件是可识别的纯文本,它的内容就是一个个的Redis标准命令.aof记录是的写redis操作的命令集合,而rdb是redis写操作的数据集合.
查看aof文件内容,使用od -c appendonly.aof,可以看到内容是set命令:
AOF重写 如果每条写命令都生成一条日志,那么AOF文件会很大,所以Redis提供了一个功能,AOF rewrite.其功能是重新生成一份AOF文件,新的AOF文件中一条记录的操作只会有一次,而不像一份老文件那样,可能记录了对同一个值的多次操作.其生成过程和RDB类似,也是fork一个进程,直接遍历数据,写入新的AOF临时文件.在写入新文件的过程中,所有的写操作日志还是会写到原来老的AOF文件中,同时还会记录在内存缓冲区中.当重完操作完成后,会将所有缓冲区中的日志一次性写入到临时文件中.然后调用原子性的rename命令用新的AOF文件取代老的AOF文件. 因此,RDB和AOF操作都是顺序IO操作,性能都很高.而同时在通过RDB文件或者AOF日志进行数据库恢复的时候,也是顺序的读取数据加载到内存中.所以也不会造成磁盘的随机读.
编程之家PHP培训学院每天发布《Redis持久化》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |