Redis持久化方式
众所周知,redis是内存数据库,在运行期间会将所有数据加载到内存中,所以如果不把数据落到磁盘的话,redis进程一旦被停掉,数据就会全部丢失。
例如:(redis持久化已关闭,看下情况)。
一开始redis里面有多个key存在,关掉重启之后,数据都已丢失。
如何把数据落到磁盘上呢?
Redis提供了两种持久化方式,分别是RDB和AOF。
一、RDB(保存数据库键对值)
(1)redis默认开启了RDB持久化方式
#下面这一行取消注释,下面三行注释掉,就是关闭RDB
#save ""
#下面三行是开启RDB持久化方式
save 900 1
save 300 10
save 60 10000
开启之后,会生成一个dump.rdb文件,这个就是数据落在磁盘上的实际存储文件。下面是对这三行配置的解读。
#每900秒内,数据库至少有1次修改就进行保存
save 900 1
#每300 秒内,数据库至少有10次修改就进行保存
save 300 10
#每60 秒内,数据库至少有10000次修改就进行保存
save 60 10000
(2)开启RDB持久化之后,数据库启动的时候就会先加载dump.rdb文件进内存 ,这个过程是阻塞的
(3)执行SAVE或BGSAVE命令可以触发RDB方式数据落盘保存
SAVE命令是阻塞的,BGSAVE命令是非阻塞的,其实上述的几秒内有至少几次修改就保存的后台也是执行的BGSAVE命令。
二、AOF(Append Only File,保存数据库执行过的命令)
(1)开启AOF持久化非常简单,配置一下两个配置项就行
#开启aof命令
appendonly yes#aof文件名称
appendfilename "appendonly.aof"
(2)开启AOF之后,redis启动会去加载aof文件,但是不会去加载rdb文件,因为aof文件的更新速度比rdb文件快,所以redis会优先加载aof文件,只有当aof没开启时,才会去加载rdb文件。
OK,这就是redis的两种持久化方式。
=======================================================
我是Liusy,一个喜欢健身的程序员。
欢迎关注微信公众号【Liusy01】,一起交流Java技术及健身,获取更多干货。