Redis的持久化!!!

首先是如何使用Redis:cmd打开输入redis-server.exe redis.windows.conf即可启动。

持久化:

Redis的高性能是由于其将所有数据都存储在了内存中,为了使Redis在重启之后仍能保证数据不丢失,需要将数据从内存中同步到硬盘中,这一过程就是持久化。

         Redis支持两种方式的持久化,一种是RDB方式,一种是AOF方式。可以单独使用其中一种或将二者结合使用。

通过配置文件:redis.windows.conf去修改持久化设置。

RDB持久化:

         RDB方式的持久化是通过快照(snapshotting)完成的,当符合一定条件时Redis会自动将内存中的数据进行快照并持久化到硬盘。

         RDB是Redis默认采用的持久化方式,在redis.conf配置文件中默认有此下配置:

save 900 1  #900秒内容如果超过1key被修改,则发起快照保存
save 300 10 #300秒内容如超过10key被修改,则发起快照保存
save 60 10000 #表示60 秒内如果超过10000key被修改,则发起快照保存

在redis.conf中:

         配置dir指定rdb快照文件的位置

         配置dbfilenam指定rdb快照文件的名称

Redis启动后会读取RDB快照文件,将数据从硬盘载入到内存。

实验:

1)、删除dump.rdb

2)、set test abc

3)、关闭服务端并观察bin目录的变化

总结:

         优点:redis的数据存取速度变快

         缺点:服务器断电时会丢失部分数据(数据的完整性得不到保证)

AOF持久化:

         默认情况下Redis没有开启AOF(append only file)方式的持久化,可以通过appendonly参数开启:appendonly yes

开启AOF持久化后每执行一条会更改Redis中的数据的命令,Redis就会将该命令写入硬盘中的AOF文件。AOF文件的保存位置和RDB文件的位置相同,都是通过dir参数设置的,默认的文件名是appendonly.aof,可以通过appendfilename参数修改:appendfilename appendonly.aof

appendfsync always     #每次有数据修改发生时都会写入AOF文件。

appendfsync everysec  #每秒钟同步一次,该策略为AOF的缺省策略。

appendfsync no          #从不同步。高效但是数据不会被持久化。

实验:

1)、删除appendonly.aof

2)、设置appendonly为yes

3)、设置一个key

4)、观察bin目录的变化

总结:

         优点:持久化良好,能包证数据的完整性

         缺点:大大降低了redis系统的存取速度

你可能感兴趣的:(redis,数据库,缓存)