缓存—Redis持久化AOF方式

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,倚天版 1GB 1个月
简介: - AOF日志:记录所有的操作命令,并以文本的形式追加到文件中- RDB快照 :将某一时刻的内存数据,以二进制方式写入磁盘- 混合持久化:Redis4.0版本后新增混合持久化方式,集成RDB和AOF的优点

上一篇中提到Redis持久化的三种方式:

  • AOF日志:记录所有的操作命令,并以文本的形式追加到文件中
  • RDB快照 :将某一时刻的内存数据,以二进制方式写入磁盘
  • 混合持久化:Redis4.0版本后新增混合持久化方式,集成RDB和AOF的优点

为什么需要持久化?

redis缓存的谁都存储在内存当中,如服务器关闭或者Redis服务器守护进程退出,那么内存中的数据就会丢失。

适用场景:把Redis当作数据库使用,储存重要业务数据时,更加需要进行将数据持久化,防止造成影响。如果仅当作缓存使用,可不用考虑持久化。

AOF

AOF:Append Only File

AOF日志实现方式

AOF持久化方式会记录客户端对服务器的每一次写操作命令,并将这些写操作以Redis协议追加保存到以aof为后缀的文件,在Redis服务器重启时,会加载并运行aof文件的命令,以恢复数据。

注意内容:

MySQL数据库都是“写前日志”,即在写数据之前,先把修改的数据记到日志文件中。如mysql的redo log。而这一点和redis是相反的。Redis先执行命令,把数据写入内存,再把日志写入文件

为什么Redis先执行命令,再把数据写入日志?

  • redis写日志之前,无需对命令进行语法检查
  • redis只记录成功的命令
  • 先执行后记录文件,避免阻塞当前的写操作

这样做,产生的不好的后果:

  • 数据可能丢失
  • 可能阻塞其他操作

开启AOF持久化方式

Redis默认不开启AOF持久化,我们自己修改redis.conf配置文件进行启动持久化

# 启动AOF机制
appendonly yes

# AOF文件名
appendfilename “appendonly.aof”

## 写入策略
appendfsync always

## 默认不重写aof文件
no-appendfsync-on-rewrite no

## 保存目录
dir ~/redis/

写入策略三种方式

appendfsync always
#appendfsync everysec
#appendfsync no
  • always:客户端的每个写操作都保存到aof文件中,这种策略安全,但每个写请求都有IO操作,所以也很慢
  • everysec:appendfsync的默认写入策略,每秒写入一次AOF文件
  • no:由操作系统负责何时写入AOF文件,Redis服务器不负责写入,所以此方式不安全,不推荐使用

AOF优缺点:

AOF优点:

  • AOF只追加日志文件,对服务器性能影响小,速度比RDB方式要快,消耗内存较少

AOF缺点:

  • AOF生成的日志文件太大
  • 恢复数据的速度比RDB慢
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
18天前
|
缓存 NoSQL 关系型数据库
(八)漫谈分布式之缓存篇:唠唠老生常谈的MySQL与Redis数据一致性问题!
本文来聊一个跟实际工作挂钩的老生常谈的问题:分布式系统中的缓存一致性。
72 10
|
5天前
|
存储 缓存 NoSQL
基于SpringBoot+Redis解决缓存与数据库一致性、缓存穿透、缓存雪崩、缓存击穿问题
这篇文章讨论了在使用SpringBoot和Redis时如何解决缓存与数据库一致性问题、缓存穿透、缓存雪崩和缓存击穿问题,并提供了相应的解决策略和示例代码。
16 0
|
5天前
|
缓存 NoSQL Ubuntu
如何在 Ubuntu 14.04 上配置 Redis 缓存以加速 WordPress
如何在 Ubuntu 14.04 上配置 Redis 缓存以加速 WordPress
10 0
|
12天前
|
缓存 NoSQL Redis
redis数据持久化之RDB和AOF
redis数据持久化之RDB和AOF
|
23天前
|
缓存 NoSQL Java
Redis 缓存与数据库数据不一致问题
Redis 缓存与数据库数据不一致问题
50 3
|
1月前
|
canal 缓存 NoSQL
Redis常见面试题(一):Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;先删除缓存还是先修改数据库,双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
Redis常见面试题(一):Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
|
20天前
|
缓存 NoSQL Serverless
函数计算产品使用问题之如何使用Redis作为缓存插件
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
23天前
|
存储 缓存 NoSQL
Redis 缓存常见问题
Redis 缓存常见问题
31 3
|
26天前
|
消息中间件 缓存 数据库
Redis问题之如何解决缓存更新失败导致的数据不一致问题
Redis问题之如何解决缓存更新失败导致的数据不一致问题