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. ...
随机推荐
- revit二次开发wpf里button按钮无法实现事务
不能在revit提供的api外部使用事务,解决此方法, 1.把button里要实现的功能写到外部事件IExternalEventHandler中,注册外部事件,在button事件中.raise()使用 ...
- vue 模板template
入门 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...
- mac 卸载通过官网下载包安装的node
sudo rm -rf /usr/local/{bin/{node,npm},lib/node_modules/npm,lib/node,share/man/*/node.*}
- H3C交换机S5500划分VLAN
好记性不如烂笔头! H3C交换机S5500划分VLAN 将H3C S5500换机现在需要分三网段,分别是VLAN14,VLAN15,VLAN16,交换机中默认全部口是VLAN1. H3 ...
- 基于hadoop分析,了解hive的使用
一.Hadoop理论 Hadoop是一个专为离线和大规模数据分析而设计的,并不适合那种对几个记录随机读写的在线事务处理模式. Hadoop=HDFS(文件系统,数据存储技术相关)+ Mapreduce ...
- Handler,Looper,MessageQueue流程梳理
目的:handle的出现主要是为了解决线程间通讯. 举个例子,android是不允许在主线程中访问网络,因为这样会阻塞主线程,影响性能,所以访问网络都是放在子线程中执行,对于网络返回的结果则需要显示在 ...
- mssql sqlserver 对不同群组对象进行聚合计算的方法分享
摘要: 下文讲述通过一条sql语句,采用over关键字同时对不同类型进行分组的方法,如下所示: 实验环境:sql server 2008 R2 当有一张明细表,我们需同时按照不同的规则,计算平均.计数 ...
- python类的继承、封装和多态
摘自https://www.cnblogs.com/evablogs/p/6724477.html 继承 1 2 3 4 5 6 7 8 class Person(object): def _ ...
- 一个特殊的SQL Server阻塞案例分析
上周,在SQL Server数据库下面遇到了一个有意思的SQL阻塞(SQL Blocking)案例.其实个人对SQL Server的阻塞还是颇有研究的.写过好几篇相关文章. 至于这里为什么要总结一下这 ...
- Vue.js01:跑马灯效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...