Redis持久化 :rdb与aof的持久化操作

redis持久化:分别启用rdb和aof,并查看是否有对应文件生成
rdb:

#save 秒钟 写操作次数  如果在设置时间内写入数据达到规定的次数,则产生一次快照
[root@localhost redis-stable]# vim /etc/redis.conf
:/save #查找有save关键字的行,如下图一所示插入命令save 60 5 
#同时关闭aof,操作 :/append 将1379行的appendonly yes 改为no (是no则不用改,如图二)
#修改文件路径 dir redis安装路径(方便查看dump.rdb文件的状态) 如图三


图一:
Redis持久化 :rdb与aof的持久化操作_第1张图片
图二:
在这里插入图片描述
图三:
在这里插入图片描述

#重启redis服务 
[root@localhost redis-stable]# systemctl restart redis
#查看rdb文件状态:
[root@localhost redis-stable]# ls -l /usr/local/src/redis-stable/dump.rdb
-rw-r--r--. 1 root root 110 Jul 25 22:21 /usr/local/src/redis-stable/dump.rdb
#运行redis-cli 插入数据
[root@localhost redis-stable]# redis-cli
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> set k4 v4
OK
127.0.0.1:6379> set k5 v5
OK
127.0.0.1:6379> set k6 v6
OK
127.0.0.1:6379> exit
#再次查看设置1min快照后的rdb文件,大小由110变为152
[root@localhost redis-stable]# ls -l /usr/local/src/redis-stable/dump.rdb
-rw-r--r--. 1 root root 152 Jul 25 22:22 /usr/local/src/redis-stable/dump.rdb

aof:

#配置:关闭rdb,如下图一所示。同时将aof的no改为yes,保存退出,重启redis。[root@localhost redis-stable]# vim /etc/redis.conf
[root@localhost redis-stable]# systemctl restart redis
#由于刚开启aof,可能会找不到appendonlydir目录,等待几分钟再次重启服务,切换到/usr/local/src/redis-stable/appendonlydir
[root@localhost redis-stable]# cd appendonlydir/
[root@localhost appendonlydir]# ll
total 8
-rw-r--r--. 1 root root 89 Jul 25 23:03 appendonly.aof.1.base.rdb
-rw-r--r--. 1 root root  0 Jul 25 23:03 appendonly.aof.1.incr.aof
-rw-r--r--. 1 root root 88 Jul 25 23:03 appendonly.aof.manifest
#启动redis并插入数据
[root@localhost appendonlydir]# redis-cli
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> set k1 v2
OK
127.0.0.1:6379> set k2 v4
OK
127.0.0.1:6379> lpush mylist 1
(integer) 1
127.0.0.1:6379> lpush mylist 2
(integer) 2
127.0.0.1:6379> lpush mylist 3
(integer) 3
127.0.0.1:6379> lpush mylist 4
(integer) 4
127.0.0.1:6379> lpush mylist 5
(integer) 5
127.0.0.1:6379> lpush mylist 6
(integer) 6
127.0.0.1:6379> lpush mylist 7
(integer) 7
127.0.0.1:6379> exit
#查看appendonlydir下文件的状态并与未插入前对比
[root@localhost appendonlydir]# ll
total 12
-rw-r--r--. 1 root root  89 Jul 25 23:03 appendonly.aof.1.base.rdb
-rw-r--r--. 1 root root 406 Jul 25 23:16 appendonly.aof.1.incr.aof
-rw-r--r--. 1 root root  88 Jul 25 23:03 appendonly.aof.manifest
#复制终端或多开一个相同的终端,重启redis并查看数据库中的key是否与重启前插入的数据一致
[root@localhost appendonlydir]# systemctl restart redis
[root@localhost appendonlydir]# redis-cli
127.0.0.1:6379> keys *
1) "mylist"
2) "k3"
3) "k2"
4) "k1"



Redis持久化 :rdb与aof的持久化操作_第2张图片
图一

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