【redis】持久化RDB和AOF

redis之持久化RDB与AOF

 

redis数据持久化

Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。html

RDB持久化

redis提供了RDB持久化的功能,这个功能能够将redis在内存中的的状态保存到硬盘中,它能够手动执行。【手动执行时经过save指令触发的】mysql

也能够再redis.conf中配置,按期执行redis

RDB持久化产生的RDB文件是一个通过压缩二进制文件,这个文件被保存在硬盘中,redis能够经过这个文件还原数据库当时的状态。sql

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   

三、登陆redis后设置一个key服务器

由于咱们要验证他的数据持久化,因此咱们登陆后须要建立一个key,用save指令触发持久化,而后杀死redis服务端的进程,app

复制代码
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文件post

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
复制代码

六、查看持久化文件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     依赖于系统自带的缓存大小机制

一、准备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

相关文章
相关标签/搜索