Redis的两种持久化方式详细介绍
一,Redis是一款基于内存的数据库,可以持久化,在企业中常用于缓存,相信大家都比较熟悉Redis了,下面主要分享下关于Redis持久化的两种模式
1、半持久化模式(RDB,filesnapshotting)
此模式是Redis默认的备份方式,通过快照方式,将数据从内存写入磁盘中,如果Redis异常退出,下次启动则从打快照的这个时间节点来恢复此之前的数据,根据数据量大小、结构、服务器性能不同,通常将记录1千万个string类主键、大小为1GB的快照文件载入内存中需要20~30s
触发快照参数在配置文件中已预设置:
save 900 1 :900s内至少1个主键被更改则进行快照
save 300 10 :300s内至少10个主键被更改则进行快照
save 60 10000 :60s内至少10000个主键被更改则进行快照
Redis实现快照的过程:当触发快照功能时,Redis的主进程会fork出一个子进程,子进程来将数据从内存中存入磁盘中,默认存放的文件名为dump.rdb,存放路径在Redis数据目录下,这些配置可以在redis.conf中调整;此时的rdb文件会覆盖之前的rdb文件。在父进程fork出子进程时,它们共享内存中的数据,当父进程接受命令请求要修改某片数据时,为了使子进程数据不受影响,这时Redis会有一种策略,就是写时复制(copy-on-write),原理是:在父进程要改动某片数据时,操作系统会把此片数据先copy一份给子进程,以保证子进程的内存数据不受影响,所以新的rdb文件就是父进程fork子进程时那一刻的内存数据。dump.rdb文件可以进行压缩(rdbcompression),节省占用空间、方便传输,也可以禁用压缩节省cpu工作负载。除了自动执行快照,还可以通过手动save和bgsave来执行快照,两者区别是,save是由主进程来进行快照操作,会阻塞其它请求,bgsave是通过fork子进程来操作。
通过RDB方式实现持久化,一旦Redis异常退出,就会丢失最后一次快照以后更改的所有数据,此时需要开发者根据具体的应用场合,通过组合设置自动快照条件的方式来将可能发生的数据损失控制在能接受的范围内。
2,全持久化模式(AOF, append-only)
此模式需要手动修改配置文件的appendonly参数,默认为no,需要改为yes
如果数据很重要无法承受损失,则使用此模式,默认Redis没有开启AOF方式的全持久化模式,在启动时Redis会逐个执行AOF文件中的命令来将硬盘中的数据载入到内存中,载入的速度较RDB模式会慢一些,开启AOF持久化后每执行一条会更改Redis数据的命令,Redis就会将该命令写入硬盘中的AOF文件,默认文件名为appendonly.aof,位置可通过appendfilename参数设置。
需要注意的是,Redis可以同时开启两种模式,既保证了数据安全性又保证了速度及操作十分容易,此时重启Redis会使用AOF文件来恢复数据,可以设置此下参数来开启AOF模式
appendonly yes 开启AOF模式
appendfilename appendonly.aof 文件名称
auto-aof-rewrite-percentage 100 当AOF文件大小超过上一次重写时的AOF文件大小的百分之多少时会再次进场重写,如果没有超过,则以启动时的AOF文件大小为依据
auto-aof-rewrite-min-size 64MB 允许重写的最小AOF文件大小配置写入AOF文件后,要求系统刷新硬盘缓存的机制
appendfsync always 每次执行写入操作都会执行同步,最安全也最慢
#appendfsync everysec 每秒执行一次同步操作
#appendfsync no 不主动进行同步操作,而是完全交由系统来操作,每30s一次,最快但不安全
Redis的两种持久化方式详细介绍的更多相关文章
- Redis的两种持久化方式-快照持久化和AOF持久化
Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为"持久化"效 ...
- Redis的两种持久化方式-快照持久化(RDB)和AOF持久化
Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为“持久化”效果. redis有两 ...
- [转载] redis 的两种持久化方式及原理
转载自http://www.m690.com/archives/371 Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串 ...
- 探究Redis两种持久化方式下的数据恢复
对长期奋战在一线的后端开发人员来说,都知道redis有两种持久化方式RDB和AOF,虽说大家都知道这两种方式大概运作方式,但想必有实操的人不会太多. 这里是自己实操两种持久化方式的一点点记录. 先看以 ...
- Redis两种持久化方式(RDB&AOF)
爬虫和转载请注明原文地址;博客园蜗牛:http://www.cnblogs.com/tdws/p/5754706.html Redis所需内存 超过可用内存怎么办 Redis修改数据多线程并发—Red ...
- Redis系列之----Redis的两种持久化机制(RDB和AOF)
Redis的两种持久化机制(RDB和AOF) 什么是持久化 Redis的数据是存储在内存中的,内存中的数据随着服务器的重启或者宕机便会不复存在,在生产环境,服务器宕机更是屡见不鲜,所以,我们希望 ...
- redis++:Redis的两种持久化 RDB 和 AOF
Redis持久化备份数据的方式有两种:RDB(Redis DataBase) . AOF(Append Only File). RDB 什么是RDB: 在指定时间间隔内,将内存中的数据集快照写入磁盘 ...
- Redis的两种持久化机制
Redis的两种持久化机制 1.持久化机制 client--->redis(内存)--->内存数据-数据持久化--->磁盘 两种方法 快照(Snapshot) AOF(Append ...
- redis两种持久化方式RDB和AOF
目录 前言 1. Redis 数据库结构 2. RDB 持久化 2.1. RDB 的创建和载入 2.1.1. 手动触发保存 SAVE 命令 BGSAVE 命令 SAVE 和 BGSAVE 的比较 2. ...
随机推荐
- C#保留2位小数几种场景总结
场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.25.可不可以刚好保留到最后一位不是 ...
- 数据结构——Java实现单链表
一.分析 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点由元素和指针构成.在Java中,我们可以将单链表定义成一个类,单链表的基 ...
- DRDS分布式SQL引擎—执行计划介绍
摘要: 本文着重介绍 DRDS 执行计划中各个操作符的含义,以便用户通过查询计划了解 SQL 执行流程,从而有针对性的调优 SQL. DRDS分布式SQL引擎 — 执行计划介绍 前言 数据库系统中,执 ...
- UML学习——类之间的关系
参考:UML图中类之间的关系:依赖,泛化,关联,聚合,组合,实现 空心菱形为聚合关系:部分与整体,部分可有可无.部分可以单独存在(车子和引擎,引擎可以单独存在) 实心菱形为组合关系:部分与整体,但是部 ...
- 读书笔记之_Win10 与Jmeter5.1.1界面兼容:
读书笔记之win10 与jmeter5.1.1界面兼容: 调整前:
- 简说Python生态系统的14年演变
[导语]Python 里各种丰富的标准库.第三方库和模块成为其广受欢迎的原因之一.而 PyPI 就是大家想第三方库前先要安装的一个仓库.作为使用者,它可以帮我们查找 Python 社区开发和共享的软件 ...
- Failure sending mail: The user or group name 'xxx\xxxx' is not recognized.Mail will not be resent
一批Reporting Service报表的订阅突然报如下错误: Failure sending mail: The user or group name 'xxx\xxxx' is not re ...
- c/c++ 继承与多态 文本查询的小例子(智能指针版本)
为了更好的理解继承和多态,做一个文本查询的小例子. 接口类:Query有2个方法. eval:查询,返回查询结果类QueryResult rep:得到要查询的文本 客户端程序的使用方法: //查询包含 ...
- vs code使用Git
做一夜的搬运工:https://www.cnblogs.com/richard1015/p/8336429.html
- jquery-hide//一段hide代码实现异步隐藏
(本篇博客没有什么参考价值,只用于自己未来复习.) 说白了就是通过“父亲”实现异步 代码: <!DOCTYPE html> <html> <head> <sc ...