redis之持久化RDB与AOF
redis数据持久化
Redis
是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis
提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。
RDB持久化
redis
提供了RDB持久化
的功能,这个功能可以将redis
在内存中的的状态保存到硬盘中,它可以手动执行。【手动执行时通过save指令触发的】
也可以再redis.conf
中配置,定期执行。
RDB持久化产生的RDB文件是一个经过压缩的二进制文件,这个文件被保存在硬盘中,redis可以通过这个文件还原数据库当时的状态。
rdb配置参数:
RDB(持久化) 内存数据保存到磁盘 在指定的时间间隔内生成数据集的时间点快照(point-in-time snapshot) 优点:速度快,适合做备份,主从复制就是基于RDB持久化功能实现 rdb通过再redis中使用save命令触发 rdb rdb配置参数: dir /data/6379/ dbfilename dbmp.rdb 每过900秒 有1个操作就进行持久化 save 900秒 1个修改类的操作 save 300秒 10个操作 save 60秒 10000个操作 save 900 1 save 300 10 save 60 10000
redis持久化之RDB实践
1.配置启动redis服务端的配置文件
# 创建log日志文件 mkdir -p /data/6380/ cd /data/6380/ touch redis.log
daemonize yes # 是否开启后台运行 port 6379 #端口 logfile /data/6379/redis.log # 自定义日志文件 dir /data/6379 #自定义持久化文件存储位置 dbfilename dbmp.rdb #rdb持久化文件 bind 192.168.61.129 #redis绑定地址 requirepass redhat #redis登录密码 save 900 1 #rdb机制 每900秒 有1个修改记录 save 300 10 #每300秒 10个修改记录 save 60 10000 #每60秒内 10000修改记录
2.通过上面的配置文件启动redis服务端
redis-server redis.conf
登录redis客户端
# --raw参数表示支持中文 redis-cli -p 6380 -h 192.168.61.129 --raw
3、登录redis后设置一个key
因为我们要验证他的数据持久化,所以我们登录后需要创建一个key,用save指令触发持久化,然后杀死redis服务端的进程,
192.168.61.129:6380> KEYS * 192.168.61.129:6380> set name "alex" OK 192.168.61.129:6380> set age 19 OK 192.168.61.129:6380> get name alex 192.168.61.129:6380> get age 19
4.此时检查目录,/data/6380底下没有dbmp.rdb文件
5.通过save触发持久化,将数据写入RDB文件
192.168.61.129:6380> KEYS * 192.168.61.129:6380> set name "alex" OK 192.168.61.129:6380> set age 19 OK 192.168.61.129:6380> get name alex 192.168.61.129:6380> get age 19 192.168.61.129:6380> SAVE OK
6、查看持久化文件dbmp.rdb
redis持久化之AOF实践
AOF(append-only log file)
记录服务器执行的所有变更操作命令(例如set del等),并在服务器启动时,通过重新执行这些命令来还原数据集
AOF 文件中的命令全部以redis协议的格式保存,新命令追加到文件末尾。
优点:最大程序保证数据不丢
缺点:日志记录非常大
redis-client 写入数据 > redis-server 同步命令 > AOF文件
配置参数
AOF持久化配置,两条参数 appendonly yes appendfsync always 总是修改类的操作 everysec 每秒做一次持久化 # 常用 no 依赖于系统自带的缓存大小机制
1、准备aof配置文件redis.conf
daemonize yes # 进程是否在后台运行 port 6380 # 端口 logfile /data/6380/redis.log # log日志 dir /data/6380 dbfilename dbmp.rdb # 数据持久化文件 bind 192.168.61.129 # 绑定ip requirepass root # 设置密码为root appendonly yes appendfsync everysec #每秒做一次持久化
2.基于配置文件启动redis服务端
redis-server /etc/redis.conf
3.检查redis数据目录/data/6380/是否产生了aof文件
[root@szx 6380]# ls appendonly.aof dbmp.rdb redis.log
4.登录redis-cli,写入数据,实时检查aof文件信息
[root@szx ~ 20:09:35]#tail -f /data/6380/appendonly.aof
5.设置新key,检查aof信息,然后关闭redis,检查数据是否持久化
[root@szx / 19:50:25]#redis-cli -p 6380 -h 192.168.61.129 --raw 192.168.61.129:6380> auth root OK 192.168.61.129:6380> KEYS * 192.168.61.129:6380> SET name "alex" OK 192.168.61.129:6380> SET age 87 OK
步骤:
修改配置文件-->启动redis服务端-->登录redis客户端-->创建key
退出客户端杀死redis服务端进程-->重启redis并登录-->查看之前创建的key是否存在
查看数据持久化的文件,所有操作记录都保存在文件中
实时监测数据持久化文件:
redis 持久化方式有哪些?有什么区别?
rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能
aof:以追加的方式记录redis操作日志的文件。可以最大程度的保证redis数据安全,类似于mysql的binlog