Redis 持久化扫盲了

charmsongo 2020-11-07 18:55:58
rdb


唠个嗑

现在的面试要求是越来越难了,想当初毕业后面试开发岗位如果你会使用 Redis ,在面试官心中就会觉得,哎呦,你挺不错哦,算是加分项。现在的 Redis 成为了开发者的必备技能,面试如果没用过或不会用 Redis,那你就真的可能被劝退了。不停的学习新技术,或许就是开发者的宿命。

持久化

Redis 可以用来做缓存,也属于 NoSQL 数据库,所以也支持数据持久化,Redis 数据库支持两种持久化方案:

  1. RDB 快照
  2. AOF 日志
  3. 混合持久化

RDB

配置参数

redis.conf 涉及的主要配置

#1、自动备份规则(满足一个条件就会触发备份动作)
save 900 1 #每隔900秒有1次修改则触发
save 300 10 #每隔300秒有10次修改则触发
save 60 10000 #每隔60秒有10000次修改则触发
#2、是否快照备份出现错误后禁止客户端写入,默认是 yes
stop-writes-on-bgsave-error yes
#3、是否对快照文件进行压缩,默认 yes
rdbcompression yes
#4、是否对 RDB 文件进行校验,默认 yes
rdbchecksum yes
#5、定义生成的 RDB 文件名,默认 dump.rdb
dbfilename dump.rdb
#6、定义生成 RDB 文件目录,默认是启动 Redis 服务的目录
dir ./

刚安装好的 Redis,默认开启的是这种持久化方式,在启动服务的目录会备份一个 dump.rdb 文件,Redis 启动的时候会自动加载这个文件来恢复备份的数据。

备份

  1. 我们可以通过 Redis 客户端发送命令 save 手动备份当前数据的快照,但是 save 是阻塞命令,当备份文件过大,备份操作没有完成时,期间接收的其他操作命令将会被挂起。所以不建议使用 save,这时候出现了 bgsave,见名知意,它会 fork 一个子进程来处理备份操作,不影响主进程处理客户端请求命令。
  2. 触发配置的自动备份策略,会自动执行 bgsave。
  3. 执行 shutdown 命令,会触发 save 命令,备份完成后才会服务关闭。
  4. 搭建主从复制时,在从机连上主机之后,会自动发送一条 sync 同步命令,主机收到命令 之后,首先执行 bgsave 对数据进行快照备份,然后才会给从机发送快照数据进行同步。

AOF

配置参数

#1、开启 aof 配置,默认 no
appendonly yes
#2、定义生成的 AOF 文件名
appendfilename "appendonly.aof"
# 3、自动备份规则(选择一个即可)
# appendfsync always #每次修改都备份
appendfsync everysec #每秒钟备份一次
# appendfsync no #由操作系统自动调度刷磁盘
#4、是否 aof 文件压缩时还继续进行同步操作,默认 no
no-appendfsync-on-rewrite no
#4、定义当目前 aof 文件大小超过上一次重写时的 aof 文件大小的百分之多少的时候,再次进行重写
auto-aof-rewrite-percentage 100
#5、如果之前没有重写过,则以启动时的 aof 大小为依据,同时要求 aof 文件至少要大于 64M
auto-aof-rewrite-min-size 64mb

默认 AOF 是没有开启的,AOF 持久化是将被执行的命令追加到 AOF 文件尾部,数据恢复时把命令从头到尾执行一遍 使用 AOF 方式做持久化,可以把 RDB 持久化的策略注释掉

save ""
#save 900 1
#save 300 10
#save 60 10000

混合持久化

此功能是 Redis4 之后新增的,说实话我也是前几天刚了解到的,接触的不多,这里也简单做个介绍吧,想深入的那只能让您失望了,出门左拐直走......

配置参数

aof-use-rdb-preamble yes

备份方式

通过上面参数设为 yes 来开启,在数据写入的时候先把数据以 RDB 的格式放在文件开头,再将后续的命令以 AOF 的格式追加到文件后面,这样算是引进了 RDB 数据恢复速度快的优点 和 AOF 数据丢失风险小的优点。

Redis 部分思维脑图

如果感觉图片不清楚,公号 charmsongo 回复 Redis 获取

如果有哪些不对的地方烦请指认,先行感谢

版权声明
本文为[charmsongo]所创,转载请带上原文链接,感谢
https://my.oschina.net/charmsongo/blog/4707644

  1. 【计算机网络 12(1),尚学堂马士兵Java视频教程
  2. 【程序猿历程,史上最全的Java面试题集锦在这里
  3. 【程序猿历程(1),Javaweb视频教程百度云
  4. Notes on MySQL 45 lectures (1-7)
  5. [computer network 12 (1), Shang Xuetang Ma soldier java video tutorial
  6. The most complete collection of Java interview questions in history is here
  7. [process of program ape (1), JavaWeb video tutorial, baidu cloud
  8. Notes on MySQL 45 lectures (1-7)
  9. 精进 Spring Boot 03:Spring Boot 的配置文件和配置管理,以及用三种方式读取配置文件
  10. Refined spring boot 03: spring boot configuration files and configuration management, and reading configuration files in three ways
  11. 精进 Spring Boot 03:Spring Boot 的配置文件和配置管理,以及用三种方式读取配置文件
  12. Refined spring boot 03: spring boot configuration files and configuration management, and reading configuration files in three ways
  13. 【递归,Java传智播客笔记
  14. [recursion, Java intelligence podcast notes
  15. [adhere to painting for 386 days] the beginning of spring of 24 solar terms
  16. K8S系列第八篇(Service、EndPoints以及高可用kubeadm部署)
  17. K8s Series Part 8 (service, endpoints and high availability kubeadm deployment)
  18. 【重识 HTML (3),350道Java面试真题分享
  19. 【重识 HTML (2),Java并发编程必会的多线程你竟然还不会
  20. 【重识 HTML (1),二本Java小菜鸟4面字节跳动被秒成渣渣
  21. [re recognize HTML (3) and share 350 real Java interview questions
  22. [re recognize HTML (2). Multithreading is a must for Java Concurrent Programming. How dare you not
  23. [re recognize HTML (1), two Java rookies' 4-sided bytes beat and become slag in seconds
  24. 造轮子系列之RPC 1:如何从零开始开发RPC框架
  25. RPC 1: how to develop RPC framework from scratch
  26. 造轮子系列之RPC 1:如何从零开始开发RPC框架
  27. RPC 1: how to develop RPC framework from scratch
  28. 一次性捋清楚吧,对乱糟糟的,Spring事务扩展机制
  29. 一文彻底弄懂如何选择抽象类还是接口,连续四年百度Java岗必问面试题
  30. Redis常用命令
  31. 一双拖鞋引发的血案,狂神说Java系列笔记
  32. 一、mysql基础安装
  33. 一位程序员的独白:尽管我一生坎坷,Java框架面试基础
  34. Clear it all at once. For the messy, spring transaction extension mechanism
  35. A thorough understanding of how to choose abstract classes or interfaces, baidu Java post must ask interview questions for four consecutive years
  36. Redis common commands
  37. A pair of slippers triggered the murder, crazy God said java series notes
  38. 1、 MySQL basic installation
  39. Monologue of a programmer: despite my ups and downs in my life, Java framework is the foundation of interview
  40. 【大厂面试】三面三问Spring循环依赖,请一定要把这篇看完(建议收藏)
  41. 一线互联网企业中,springboot入门项目
  42. 一篇文带你入门SSM框架Spring开发,帮你快速拿Offer
  43. 【面试资料】Java全集、微服务、大数据、数据结构与算法、机器学习知识最全总结,283页pdf
  44. 【leetcode刷题】24.数组中重复的数字——Java版
  45. 【leetcode刷题】23.对称二叉树——Java版
  46. 【leetcode刷题】22.二叉树的中序遍历——Java版
  47. 【leetcode刷题】21.三数之和——Java版
  48. 【leetcode刷题】20.最长回文子串——Java版
  49. 【leetcode刷题】19.回文链表——Java版
  50. 【leetcode刷题】18.反转链表——Java版
  51. 【leetcode刷题】17.相交链表——Java&python版
  52. 【leetcode刷题】16.环形链表——Java版
  53. 【leetcode刷题】15.汉明距离——Java版
  54. 【leetcode刷题】14.找到所有数组中消失的数字——Java版
  55. 【leetcode刷题】13.比特位计数——Java版
  56. oracle控制用户权限命令
  57. 三年Java开发,继阿里,鲁班二期Java架构师
  58. Oracle必须要启动的服务
  59. 万字长文!深入剖析HashMap,Java基础笔试题大全带答案
  60. 一问Kafka就心慌?我却凭着这份,图灵学院vip课程百度云