篇首语:本文由编程笔记#小编为大家整理,主要介绍了Redis数据库——Redis高可用持久化及性能管理相关的知识,希望对你有一定的参考价值。
由于AOF持久化的实时性更好,即当进程意外退出时丢失的数据更少,因此AOF是目前主流的持久化方式,不过RDB持久化仍然有其用武之地
①、手动触发
②、自动触发
vim /etc/redis/6379.conf
#----219行----以下三个save条件满足任意一个时,都会引起bgsave的调用
save 900 1 :当时间到900秒时,如果redis数据发生了至少1次变化,则执行bgsave
save 300 10 :当时间到300秒时,如果redis数据发生了至少10次变化,则执行bgsave
save 60 10000 :当时间到60秒时,如果redis数据发生了至少10000次变化,则执行bgsave
#----242行----是否开启RDB文件压缩
rdbcompression yes
#----254行----指定RDB文件名
dbfilename dump.rdb
#----264行----指定RDB文件和AOF文件所在目录
dir /var/lib/redis/6379
③、其他自动触发机制
执行流程
启动时加载
开启AOF
Redis服务器默认开启RDB,关闭AOF;要开启AOF,需要在配置文件中配置:
vim /etc/redis/6379.conf
#----700行----修改;开启AOF
appendonly yes
#----704行----指定AOF文件名称
appendfilename "appendonly.aof"
#----796行----是否忽略最后一条可能存在问题的指令
aof-load-truncated yes
#指redis在恢复时,会忽略最后一条可能存在问题的指令,默认为yes,即在aof写入时,可能存在指令错误的问题(突然断电导致未执行结束),这种情况下,yes会log并继续,而no会直接恢复失败
/etc/init.d/redis_6379 restart
#需要先取消密码
执行流程
文件重写之所以能够压缩AOF文件,原因在于:
过期的数据不再写入文件
无效的命令不再写入文件:如有些数据被重复设值(set mykey v1, set mykey v2)、有些数据被删除了(sadd myset v1, del myset)等。
多条命令可以合并为一个:如sadd myset v1, sadd myset v2, sadd myset v3可以合并为sadd myset v1 v2 v3。
通过上述内容可以看出,由于重写后AOF执行的命令减少了,文件重写既可以减少文件占用的空间,也可以加快恢复速度。
vim /etc/redis/6379.conf
#----729行----
auto-aof-rewrite-percentage 100
#当前AOF文件大小(即aof_current_size)是上次日志重写时AOF文件大小(aof_base_size)的两倍时,发生bgrewriteaof操作
auto-aof-rewrite-min-size 64mb
#当前AOF文件执行bgrewriteaof命令的最小值,避免刚开始启动redis时由于文件尺寸较小导致频繁的bgrewriteaof
注意:
重写由父进程fork子进程进行
重写期间Redis执行的写命令,需要追加到新的AOF文件中,为此Redis引入了aof_rewrite_buf缓存。
redis-cli -h 192.168.184.10 -p 6379
info memory
配置文件中修改 maxmemory-policy 属性值:
vim /etc/redis/6379.conf
#----598取消注释----
maxmemory-policy noenviction
volatile-lru :使用LRU算法从已设置过期时间的数据集合中淘汰数据
volatile-ttl :从已设置过期时间的数据集合中挑选即将过期的数据淘汰
volatile-random :从已设置过期时间的数据集合中随机挑选数据淘汰
allkeys-lru :使用LRU算法从所有数据集合中淘汰数据
allkeys-random :从数据集合中任意选择数据淘汰
noenviction :禁止淘汰数据