Redis宕机,如何避免数据丢失和快速恢复?
你会把Redis应用到什么业务场景上?你大概率会说:“会把它当缓存使用,直接从内存读取数据,响应速度快”。没错,这是Redis最普遍使用的业务场景,但是不可忽视一个问题:一旦服务器宕机,内存中的数据将全部丢失。
首先可能大家很容易想到的一个解决方案是:从后端数据库恢复这些数据。这个方案会带来2个问题:一是,需要频繁访问数据库,会给数据库带来巨大的压力;二是,这些数据是从慢速数据库中读取出来的,性能肯定比不上从 Redis 中读取,导致使用这些数据的应用程序响应变慢。Redis 为我们提供了2种持久化机制,即 AOF(Append Only File)日志和 RDB 快照。
AOF 日志是如何实现的?
AOF 日志实现:AOF 日志记录的是所执行的每一条操作指令,Redis 是先执行命令,把数据写入内存,然后才记录日志,如下图所示:
为什么要执行命令后再记录日志?
这样的好处:先让系统执行命令,只有命令能执行成功,才会被记录到日志中,否则,系统就会直接向客户端报错。可以避免出现记录错误命令的情况。还有一个好处是:它是在命令执行后才