redis是一种可内存也可持久化的内存数据库,所谓持久化,就是将数据放到断电后数据不会丢失的设备中,也就是通常理解的磁盘上.

redis配置文件whereis redis.conf

redis: /etc/redis.conf

每一个配置项的含义看链接:https://redis.io/topics/config在redis启动的前提下

config get * //可以看到部分配置项

其他配置项可以通过config get xxx 获取

并可以使用config set key value进行配置

redis持久化策略

第一种:RDB快照

Redis支持将当前数据的快照存成一个数据文件的持久化机制.而一个持续写入的数据库如何生成快照呢?Redis借助fork命令的copy on write机制.在生成快照时,将当前进程fork出一个子进程,然后在子进程中循环所有的数据,将数据写成为RDB文件.

通过Redis的save指令来配置RDB快照生成规则,配置方式有两种;

一是配置Redis.conf

二是通过config set 命令在Redis运行时配置,不需重启Redis

查看save规则:redis 127.0.0.1:6379> config get save

1) "save"

2) "3600 1 300 100 60 10000"

RDB文件写操作是在一个新进程中进行的,子进程会先将数据写入临时文件,然后通过原子性rename系统调用将临时文件重命名为RDB文件;当然,Redis的RDB文件也是Redis主从同步内部实现中的一环,使用od -c命令查看rdb文件内容,可以看到保存的实际是数据本身.[www@xxxx]$ od -c dump.rdb

0000000 R E D I S 0 0 0 2 376 \0 \0 003 s e x
0000020 004 m a l e \0 004 n a m e 004 j a c k
0000040 377
0000041

第二种:AOF日志

aof全称append only file,它是一个追加写入的日志文件.与一般数据库的binlog不同的是,AOF文件是可识别的纯文本,它的内容就是一个个的Redis标准命令.aof记录是的写redis操作的命令集合,而rdb是redis写操作的数据集合.redis 127.0.0.1:6379> config get appendonly

1) "appendonly"

2) "no"

设置为yes

redis 127.0.0.1:6379> config set appendonly yes

那么执行save/bgsave,就会生成appendonly.aof文件

查看aof文件内容,使用od -c appendonly.aof,可以看到内容是set命令:*2

$6
SELECT
$1
0
*3
$3
set
$3
sex
$4
male
*3
$3
set
$4
name
$4
jack

AOF重写

如果每条写命令都生成一条日志,那么AOF文件会很大,所以Redis提供了一个功能,AOF rewrite.其功能是重新生成一份AOF文件,新的AOF文件中一条记录的操作只会有一次,而不像一份老文件那样,可能记录了对同一个值的多次操作.其生成过程和RDB类似,也是fork一个进程,直接遍历数据,写入新的AOF临时文件.在写入新文件的过程中,所有的写操作日志还是会写到原来老的AOF文件中,同时还会记录在内存缓冲区中.当重完操作完成后,会将所有缓冲区中的日志一次性写入到临时文件中.然后调用原子性的rename命令用新的AOF文件取代老的AOF文件.

因此,RDB和AOF操作都是顺序IO操作,性能都很高.而同时在通过RDB文件或者AOF日志进行数据库恢复的时候,也是顺序的读取数据加载到内存中.所以也不会造成磁盘的随机读.参考文档:

https://redis.io/topics/config

https://redis.io/topics/persistence