## # Redis持久化介绍php
全部的数据都存在内存中,从内存当中同步到硬盘上,这个过程叫作持久化过程。持久化操做,两种方式:rdb方式、aof方式,能够单独使用或者结合使用。redis
rdb持久化方法:在指定的时间间隔写入硬盘 aof方式:将以日志,记录每个操做,服务器启动后就构建数据库。数据库
RDB方式 Redis是默认支持的安全
优点:只有一个文件,时间间隔的数据,能够归档为一个文件,方便压缩转移(就一个文件)服务器
## #Redis的持久化之RDB方式**app
劣势:若是宕机,数据损失比较大,由于它是每个时间段进行持久化操做的。也就是积攒的数据比较多,一旦懵逼,就完全懵逼了url
[root@hdp-01 redis]# vi redis.conf spa
往下拉:3d
这里save 900 1 表示 每900秒内至少有1个kery发生变化 就持久化日志
save 300 10表示 每300秒内至少有10个key发生变化 就持久化
save 60 10000表示 每60秒内至少有10000个key发生变化 就持久化
再往下拉
这里有个dbfilename配置 是保存的持久化的文件名 默认是dump.rdb
dir ./ 表示文件存储路径是当前路径
退出
[root@hdp-01 redis]# ll总用量 64drwxr-xr-x. 2 root root 134 9月 1 16:30 bin-rw-r--r--. 1 root root 109 9月 1 17:30dump.rdb-rw-r--r--. 1 root root 58767 9月 3 07:04 redis.conf
当前路径里确实是有这个文件的
## # RDB备份和恢复数据
假如遇到断电或者宕机或者天然灾害 须要恢复数据 咱们模拟下 先重置下数据
shutdown关闭下redis
127.0.0.1:6379> shutdown
not connected> exit
[root@hdp-01redis]# ll
总用量 52
drwxr-xr-x. 2 root root bin-rw-r--r--. 1 root root dump.rdb-rw-r--r--. 1 root root redis.conf
删掉rdb文件 再启动redis 这时候启动 是没数据的
[root@hdp-01]# rm -rf dump.rdb [root@hdp-01redis]# ./bin/redis-server ./redis.conf [root@hdp-01redis]# ./bin/redis-cli127.0.0.1:6379> keys *(empty list or set)
搞几个key 而后shutdown save 保存退出
[url=]
[/url]
127.0.0.1:6379> set n1 1OK127.0.0.1:6379> set n2 2OK127.0.0.1:6379> set n3 3OK127.0.0.1:6379> shutdown savenot connected> exit[url=]
[/url]
假如这时候 咱们再重启redis 这时候启动过程会进程rdb check验证 而后加载redis目录下rdb文件 加载数据
验证下:咱们再次启动
[url=]
[/url]
[root@hdp-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *1) "n1"2) "n3"3) "n2"[url=]
[/url]
说明是数据加载进来了
这里咱们把redis下的rdb文件剪切到其余地方去 而后再启动试下
[root@hdp-01 redis]# mv dump.rdb /root/
剪切到root下
这时候再启动下
[root@hdp-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *(empty list or set)
发现全部数据都没了 恢复数据的话 咱们只须要把备份文件搞到redis下便可
[url=]
[/url]
[root@hdp-01 redis]# cp /root/dump.rdb /usr/local/redis/cp:是否覆盖"/usr/local/redis/dump.rdb"? y[root@hdp-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *1) "n2"2) "n1"3) "n3"[url=]
[/url]
## #Redis的持久化之AOF方式**
AOF方式:将以日志,记录每个操做
优点:安全性相对RDB方式高不少
劣势:效率相对RDB方式低不少
## # AOF备份和恢复数据
AOF方式:将以日志,记录每个操做
优点:安全性相对RDB方式高不少;劣势:效率相对RDB方式低不少;
配置:
[root@hdp-01 redis]# vi redis.conf
编辑redis.conf
appendonly no默认关闭aof方式 咱们修改为yes 就开启
下面那个是默认的aof文件名
再往下拉:
这里是三种同步策略:
always 是 只要发生修改 当即同步 (推荐实用 安全性最高)
everysec 是 每秒同步一次
no是不一样步
修改为always
从新启动redis 随便加几个key
这里就有一个appendonly.aof文件
重置数据
[root@hdp-01 redis]# rm -rf dump.rdb
启动redis
[root@hdp-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *(empty list or set)
目前数据库是空 添加数据
[url=]
[/url]
127.0.0.1:6379> set n1 1OK127.0.0.1:6379> set n2 2OK127.0.0.1:6379> set n3 3OK127.0.0.1:6379> shutdown nosavenot connected> exit[url=]
[/url]
把aof文件剪切到其余地方 启动
[root@hdo-01 redis]# mv appendonly.aof /root/[root@hdo-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *(empty list or set)
咱们再把aof文件复制回来
[url=]
[/url]
[root@hdp-01 redis]# cp /root/appendonly.aof /usr/local/redis/cp:是否覆盖"/usr/local/redis/appendonly.aof"? y[root@hdp-01 redis]# ./bin/redis-server ./redis.conf [root@hdp-01 redis]# ./bin/redis-cli127.0.0.1:6379> keys *1) "n1"2) "n3"3) "n2"[url=]
[/url]