redis的持久化
Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。
rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能;
aof:以追加的方式记录redis操作日志的文件。可以最大程度的保证redis数据安全,类似于mysql的binlog
同时设置rdb和aof持久化,aof优先起作用
rdb持久化:
rdb持久化简介
可以将redis在内存中的的状态保存到硬盘中;
可以手动执行save;
也可以再redis.conf中配置,定期执行;
RDB持久化产生的RDB文件是一个经过压缩的二进制文件,这个文件被保存在硬盘中,redis可以通过这个文件还原数据库当时的状态;
优点:速度快,适合做备份,主从复制就是基于RDB持久化功能实现
rdb持久化配置文件(redis_rdb.conf)
1.配置参数
dir /data/6379 #定义持久化文件存储位置
dbfilename dbmp.rdb #指定rdb持久化文件
save 900 1 #rdb机制 每900秒 有1个修改记录
save 300 10 #每300秒 10个修改记录
save 60 10000 #每60秒内 10000修改记录
客户端的修改数据会依据配置文件中的save配置(参数可以自行修改)进行自动保存更新dbmp.rdb 文件,或者通过手动save即时保存更新
2.编辑新建配置文件-------vim /opt/redis-4.0.10/redis_rdb.conf-------配置时注意删掉注释,不然报错
3.配置文件(注意绑定ip,远程访问时必须对应ip和端口)
daemonize yes #开启守护进程,后台运行
bind 192.168.160.135 #redis绑定地址
port 6379 #redis指定端口
protected-mode yes #开启redis的安全模式,必须输入密码才可以远程登录
requirepass 123456 #redis登录密码
logfile /data/6379/redis.log #指定日志输出的文件
dir /data/6379 #定义持久化文件存储位置
dbfilename dbmp.rdb #指定rdb持久化文件
save 900 1 #rdb机制 每900秒 有1个修改记录
save 300 10 #每300秒 10个修改记录
save 60 10000 #每60秒内 10000修改记录
启动redis服务端
指定自定义配置的rdb配置文件启动---------redis-server /opt/redis-4.0.10/redis_rdb.conf
启动redis客户端
默认直接redis-cli,指定 redis-cli -h 192.168.160.135 -p 6379 -a 123456
持久化文件dbmp.rdb的更新
客户端的操作会根据服务端启动配置文件redis_rdb.conf中的save对操作记录文件dbmp.rdb进行自动更新
客户端执行save进行手动即时更新保存
操作上之后手动执行save或者自动执行之后查看ls /data/6379/ 会自动生成dbmp.rdb
当服务端重启关闭后,可以直接指定配置文件redis_rdb.conf启动服务端,数据会从dbmp.rdb中进行自动读取复原
aof持久化
aof持久化简介
AOF(append-only log file);
记录服务器执行的所有变更操作命令(例如set del等),并在服务器启动时,通过重新执行这些命令来还原数据集;
AOF 文件中的命令全部以redis协议的格式保存,新命令追加到文件末尾。;
优点:最大程序保证数据不丢;
缺点:日志记录非常大
aof持久化配置文件(redis_aof.conf)
配置参数
AOF持久化配置,两条参数
appendonly yes
appendfsync always 总是修改类的操作
everysec 每秒做一次持久化
no 依赖于系统自带的缓存大小机制
编辑新建配置文件-----------vim /opt/redis-4.0.10/redis_aof.conf
配置文件(注意绑定ip,远程访问时必须对应ip和端口)
daemonize yes
bind 192.168.160.135
port 6381
protected-mode yes
requirepass 123456
logfile /data/6381/redis.log
dir /data/6381
appendonly yes
appendfsync everysec
启动redis服务端:指定自定义配置的aof配置文件启动---------redis-server /opt/redis-4.0.10/redis_aof.conf
启动redis客户端-----登录:redis-cli -h 192.168.160.135 -p 6381 -a 123456 -------------用户操作记录会自动保存更新在/data/6381/appendonly.aof 文件中
当服务端重启关闭后,可以直接指定配置文件redis_aof.conf启动服务端,数据会从/opt/redis-4.0.10/redis_aof.conf 中进行自动读取复原