Redis
是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis
提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。mysql
如今最新版默认RDB 持久化web
redis
提供了RDB持久化
的功能,这个功能能够将redis
在内存中的的状态保存到硬盘中,它能够手动执行。redis
也能够再redis.conf
中配置,按期执行。sql
RDB持久化产生的RDB文件是一个通过压缩的二进制文件,这个文件被保存在硬盘中,redis能够经过这个文件还原数据库当时的状态。数据库
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
1.启动redis服务端,准备配置文件缓存
daemonize yes port 6379 logfile /data/6379/redis.log dir /data/6379 #定义持久化文件存储位置 dbfilename dbmp.rdb #rdb持久化文件 bind 10.0.0.10 127.0.0.1 #redis绑定地址 requirepass redhat #redis登陆密码 save 900 1 #rdb机制 每900秒 有1个修改记录 save 300 10 #每300秒 10个修改记录 save 60 10000 #每60秒内 10000修改记录
2.启动redis服务端安全
3.登陆redis设置一个key服务器
redis-cli -a redhat
4.此时检查目录,/data/6379底下没有dbmp.rdb文件app
5.经过save触发持久化,将数据写入RDB文件ui
127.0.0.1:6379> set age 18 OK 127.0.0.1:6379> save OK
AOF(append-only log file)
记录服务器执行的全部变动操做命令(例如set del等),并在服务器启动时,经过从新执行这些命令来还原数据集
AOF 文件中的命令所有以redis协议的格式保存,新命令追加到文件末尾。
优势:最大程序保证数据不丢
缺点:日志记录很是大
redis-client 写入数据 > redis-server 同步命令 > AOF文件
AOF持久化配置,两条参数
appendonly yes
appendfsync always 老是修改类的操做
everysec 每秒作一次持久化
no 依赖于系统自带的缓存大小机制
daemonize yes port 6379 logfile /data/6379/redis.log dir /data/6379 dbfilename dbmp.rdb requirepass redhat save 900 1 save 300 10 save 60 10000 appendonly yes appendfsync everysec
redis-server /etc/redis.conf
[root@web02 6379]# ls appendonly.aof dbmp.rdb redis.log
[root@web02 6379]# tail -f appendonly.aof
redis-cli -a redhat shutdown redis-server /etc/redis.conf redis-cli -a redhat
redis 持久化方式有哪些?有什么区别?
rdb:基于快照的持久化,速度更快,通常用做备份,主从复制也是依赖于rdb持久化功能
aof:以追加的方式记录redis操做日志的文件。能够最大程度的保证redis数据安全,相似于mysql的binlog