redis生产环境持久化方案

redis生产环境持久化方案

  • redis持久化机制对于生产环境的意义

对于大型系统来说,缓冲通常数据量很大,如果redis宕机了,那么从数据库再载入数据到redis中会很慢的,所以持久化意义在于故障的快速恢复。

  • RDB和AOF

RDB每隔一段时间生成内存快照。AOF存储的是写指令,当redis一直写入,达到内存限制时,redis会通过LRU清理数据掉数据,此时AOF文件可能还没清理,之后redis继续写入,当AOF大到一定程度时,会基于redis的最新数据进行AOF的rewrite,重新生成AOF文件,并删掉旧的文件。同时开启会使用AOF,因为AOF更为实时。

  • RDB和AOF两只机制对比

RDB适合做冷备,将RDB副本拷贝到备份主机上。可以让redis仍然保持高性能,对redis读写影响非常小,fork子进程去进行RDB持久化,而AOF每条命令都要写磁盘。RDB重启和恢复redis更快,因为AOF要回放所有指令。

  • RDB缺点

1.可能丢数据。2.当数据很多时,可能会暂停给客户端提供服务。

  • AOF优点

1.每隔一秒fsync,丢失数据少。2.AOF日志文件非常可读。

  • AOF的缺点

1.AOF日志文件大。2.AOF的QPS比RDB低,因为每秒fsync一次。3.健壮性低。4.数据恢复慢,做冷备不方便。

  • 选择哪种备份机制

两者都用,混合持久化。

  • 安全退出机制

reids-cli SHUTDOWN退出时,会持久化数据。

  • RDB配置方法

1.save 5 1, 5秒有1个key变化,就进行备份。默认是打开了RDB,有默认配置的检查点。

  • AOF配置方法

appendonly yes,fsync的执行策略,推荐使用everysec.

  • AOF rewrite

reids数据其实是有限的,而且会不断淘汰,被清理掉的写日志还在aof中,所以aof会fork子进程去rewrite,基于现有内存数据重做。auto-aof-rewrite-percentage 600

auto-aof-rewrite-min-size 64mb

在这里插入图片描述

  • 实际生产环境:AOF和RDB同时工作

1.RDB在的snapshotting和AOF的rewrite是互斥的

2.如果snapshotting在执行,手动运行BGREWRITE,会等snapshotting执行完之后再rewrite。

3.同时有rdb及AOF,redis重启时,会使用AOF进行数据恢复。

  • AOF文件有破损的情况修复

redis-check-aof fix

  • redis不能支撑高并发的瓶颈在哪

单机redis在上万到几万不等;如果redis的QPS要超过10万+,要做读写分离。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Redis提供了两种方式来实现数据持久:RDB(Redis Database)和AOF(Append-Only File)。 1. RDB持久: RDB是Redis的默认持久方式,它将当前内存中的数据保存到磁盘上的一个二进制文件。RDB持久可以在指定的时间间隔内自动执行,也可以手动执行。当执行RDB持久时,Redis会fork一个子进程来将数据写入到磁盘上的文件中,完成后再替换原有的文件。RDB持久适用于数据备份和恢复,以及在重启Redis时快速加载大量数据。 配置RDB的方式: 在Redis配置文件中,可以通过设置`save`指令来配置RDB持久的触发条件和频率。例如,`save 3600 1`表示在1个小时内,如果至少有1个键被修改,则执行RDB持久。 2. AOF持久: AOF持久以日志追加的方式将每个写操作命令追加到一个文件中。通过重新执行这些命令,可以将数据恢复到Redis服务器重新启动之前的状态。AOF持久方式相对于RDB更加耐久,因为它记录了每个写操作命令,可以在服务异常终止时更好地保证数据的完整性。 配置AOF的方式: 在Redis配置文件中,可以通过设置`appendonly`指令来启用AOF持久。默认情况下,AOF持久是关闭的。可以设置`appendfsync`指令来控制AOF文件何时被同步到磁盘。常用的选项有`always`(每个写命令都立即同步到磁盘,最安全但性能较差)、`everysec`(每秒同步一次,折衷方案)和`no`(操作系统决定何时同步,性能最好但风险较高)。 可以根据实际需求选择适合的持久方式,或者同时使用RDB和AOF来提高数据的安全性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值