持久化-AOF 持久化策略基本操作|学习笔记

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 快速学习持久化-AOF 持久化策略基本操作

开发者学堂课程【Redis 入门到精通(进阶篇)持久化-AOF 持久化策略基本操作】学习笔记与课程紧密联系,让用户快速学习知识

课程地址https://developer.aliyun.com/learning/course/765/detail/13424


持久化-AOF 持久化策略基本操作

 

内容介绍

一、AOF 写数据过程

二、AOF 写数据三种策略

三、AOF 功能开启

四、演示过程

五、AOF 功能开启

 

一、AOF 写数据过程

image.png

据上图,当客户端发出一条指令到服务器时,服务器接收到指令并没有马上记录,而是放到临时区域,这个区域即 AOF 写命令刷新缓存区,若还有指令依旧放在缓存区,这些指令最终生成.aof 存储文件,到一定阶段,将命令同步到 AOF 文件中。

 

二、AOF 写数据三种策略

1、always(每次)

每次写入操作均同步到 AOF 文件中,数据零误差,性能较低,不建议使用

2、everysec(每秒)

每秒将缓冲区中的指令同步到 AOF 文件中,数据准确性较高,性能较高,建议使用,也是默认配置

在系统中突然宕机的情况下丢失1秒内的数据

3、no(系统控制)

由操作系统控制每次同步到 AOF 文件的周期,整体过程不可控

 

三、AOF 功能开启

1、配置

appandonly  yes | no

2、作用

是否开启 AOF 持久化功能,默认为不开启状态

3、配置

appandfsync  always | everysec | no

4、作用

AOF 写数据策略

 

四、演示过程

1、测试 always

进入 conf 文件进行修改

[root@localhost conf]# vim redis-6379.conf

开启对 AOF 支持

appendonly yes

指定 AOF 策略

appandfsync always

启动

[root@localhost conf]# redis-server redis-6379.conf

在数据目录中看效果

[root@localhost conf]#cd.

[root@localhost redis-4.0.4]#cd data

[root@localhost data]#ll

total28

-rm-r--r--.1 root root 22979 Oct 13 19:34 6379.log

-rm-r--r--.1 root root     0 Oct 13 19:32 appengonly.aof (此文件为 AOF 的持久化存储文件)

-rm-r--r--.1 root root   157 Oct 13 19:34 dump-6379.rdb

[root@localhost data]#

在客户端进行连接

[root@localhost /]#redis-cli

127.0.0.1:6379>set name 123

OK

127.0.0.1:6379>

在左侧服务端进行查看,文件里有内容

在客户端接着进行

127.0.0.1:6379> lpush list1 a b c d e

(integer) 5

在左侧服务端接着查看文件,文件变大

从上述演示可看出 always 每执行一个指令时,会记录一次。

在右侧执行 get 指令

127.0.0.1:6379>get name

“123”

127.0.0.1:6379>

在左侧发现没有变化,查看具体内容

[root@localhost data]# Cat appendonly.aof

文件打开后,可以阅读。

从上述演示可看出 always 每执行一个指令,保存一个指令。

2、测试 everysec

进入文件

[root@localhost data]#cd.

[root@localhost redis-4.0.4]#cd conf

[root@localhost conf]# vim redis-6379.conf

改配置文件

appendonly yes

appendfsync everysec

由于 everysec 每秒存储一次,速度很快,几乎看不出与每次一存 always 的区别,但也可以进行存储。

左侧服务端重新启动

[root@localhost conf]# ps -ef | grep redis-

root   8985     1  0   19:52  ?    00:00:00  redis-server  *:6379

root   9124  8551  0   19:57 pts/0  00:00:00  grep-color-auto redis-

[root@localhost conf]# kill -s 9  8985

重新启动

[root@localhost conf]# redis-serve redis-6379.conf

[root@localhost conf]#

此时已换成全新配置,右侧客户端进行连接

[root@localhost/]# redis-cli

127.0.0.1:6379>

此时查看数据文件,数据已进入。

 

五、AOF功能开启

1、配置

Appendfilenama filename

2、作用

AOF持久化文件名,默认文件名为 appendonly.aof,建议配置为 appendonly-端口号.afo

3、配置

dir

4、作用

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
相关文章
|
NoSQL Redis 数据安全/隐私保护
redis的 rdb 和 aof 持久化方式的区别及使用场景
redis的 rdb 和 aof 持久化方式的区别及使用场景
305 0
|
4月前
|
监控 NoSQL Redis
Redis问题之什么是AOF持久化,它有哪些优点和缺点
Redis问题之什么是AOF持久化,它有哪些优点和缺点
|
5月前
|
存储 NoSQL Redis
《面试官之你说我听》:简明的图解Redis RDB持久化、AOF持久化
《面试官之你说我听》:简明的图解Redis RDB持久化、AOF持久化
|
6月前
|
存储 NoSQL 关系型数据库
Redis持久化策略AOF、RDB详解及源码分析
Redis持久化策略AOF、RDB详解及源码分析
|
存储 NoSQL 关系型数据库
Redis的持久化策略(RDB、AOF、RDB-AOF混合持久化)
Redis的持久化策略(RDB、AOF、RDB-AOF混合持久化)
161 0
|
存储 NoSQL Redis
Redis持久化方式~RDB 持久化和AOF 持久化
Redis持久化方式~RDB 持久化和AOF 持久化
116 0
|
缓存 NoSQL Redis
Redis(二十六)-持久化操作之AOF
上一篇文章我们介绍了 Redis(二十五)-持久化操作之RDB ,这篇文章接着来介绍另一种持久化的方式AOF。
268 0
Redis(二十六)-持久化操作之AOF
|
NoSQL Redis 数据安全/隐私保护
Redis如何实现持久化(AOF、RDB、混合模式)的优缺点
Redis如何实现数据不丢失 Redis的读写操作都是在内存中,所以Redis性能才会高,但是当Redis重启后,内存中的数据就会丢失,那为了保存内存中的数据不会丢失,Redis实现了数据持久化机制,会把数据保存到磁盘,这样Redis重启就能够从磁盘恢复原有的数据
250 0
Redis如何实现持久化(AOF、RDB、混合模式)的优缺点
|
运维 NoSQL 大数据
持久化-RDB与AOF方案对比|学习笔记
快速学习持久化-RDB 与 AOF 方案对比
持久化-RDB与AOF方案对比|学习笔记
|
存储 分布式计算 NoSQL
持久化-持久化简介|学习笔记
快速学习持久化-持久化简介
持久化-持久化简介|学习笔记