一,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的两种持久化方式详细介绍的更多相关文章

  1. Redis的两种持久化方式-快照持久化和AOF持久化

    Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为"持久化"效 ...

  2. Redis的两种持久化方式-快照持久化(RDB)和AOF持久化

    Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为“持久化”效果. redis有两 ...

  3. [转载] redis 的两种持久化方式及原理

    转载自http://www.m690.com/archives/371 Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串 ...

  4. 探究Redis两种持久化方式下的数据恢复

    对长期奋战在一线的后端开发人员来说,都知道redis有两种持久化方式RDB和AOF,虽说大家都知道这两种方式大概运作方式,但想必有实操的人不会太多. 这里是自己实操两种持久化方式的一点点记录. 先看以 ...

  5. Redis两种持久化方式(RDB&AOF)

    爬虫和转载请注明原文地址;博客园蜗牛:http://www.cnblogs.com/tdws/p/5754706.html Redis所需内存 超过可用内存怎么办 Redis修改数据多线程并发—Red ...

  6. Redis系列之----Redis的两种持久化机制(RDB和AOF)

    Redis的两种持久化机制(RDB和AOF) 什么是持久化    Redis的数据是存储在内存中的,内存中的数据随着服务器的重启或者宕机便会不复存在,在生产环境,服务器宕机更是屡见不鲜,所以,我们希望 ...

  7. redis++:Redis的两种持久化 RDB 和 AOF

    Redis持久化备份数据的方式有两种:RDB(Redis DataBase) . AOF(Append Only  File). RDB 什么是RDB: 在指定时间间隔内,将内存中的数据集快照写入磁盘 ...

  8. Redis的两种持久化机制

    Redis的两种持久化机制 1.持久化机制 client--->redis(内存)--->内存数据-数据持久化--->磁盘 两种方法 快照(Snapshot) AOF(Append ...

  9. redis两种持久化方式RDB和AOF

    目录 前言 1. Redis 数据库结构 2. RDB 持久化 2.1. RDB 的创建和载入 2.1.1. 手动触发保存 SAVE 命令 BGSAVE 命令 SAVE 和 BGSAVE 的比较 2. ...

随机推荐

  1. Vue + WebApi 小项目:构造自己的在线 Markdown 笔记本应用

    Vue + WebApi 小项目:构造自己的在线 Markdown 笔记本应用 目录 概要 知识点 完整示例图 代码与资源文件 流程步骤 概要 基于 MVP 最小可行性产品设计理念,我们先完成一个可以 ...

  2. cesium 之地图显示坐标、比例尺、海拔高度效果篇(附源码下载)

    前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 内 ...

  3. 【esri-loader】帮助文档翻译 part2 用法

    esri-loader怎么用?看完不要太清楚. [未完待续]!!! Q1: 在哪里用? 这是我最疑惑的问题之一,我知道要用esri-loader,肯定是某条js导入语句起作用的,但是你得告诉我写在哪里 ...

  4. IGP和BGP路由协议配合降低非核心路由器的路由容量的实验与总结

    IGP和BGP路由协议配合降低非核心路由器的路由容量的实验与总结 一.结论 通过eBGP协议,可以显著降低对非核心路由器的路由容量要求,因为核心路由器的数量明显少于非核心路由器,所以,通过此措施既可以 ...

  5. HTML5 新增的 input 事件

    以往 HTML 的 input 輸入框,無法即時反映使用者的輸入內容.onkeyup.onkeydown 事件,無法即時.精確地取得使用者的輸入資料:而 onchange.onblur 事件,要等到失 ...

  6. Linux安装配置Mariadb

    一.安装数据库Mariadb 参考:http://blog.51cto.com/12173069/2047746 从最新版本的linux系统开始,默认的是 Mariadb而不是mysql! 使用系统自 ...

  7. C# 匿名对象(匿名类型)、var、动态类型 dynamic——实用之:过滤类属性、字段实用dynamic

    例子 返回一个LIst<oject>类型 而oject含有 30个字段 而我只需要两个字段.这里实用dynamic 和 linq. 上代码: 注意select new {} 为匿名类型,这 ...

  8. 使用Let's Encrypt生成免费SSL证书操作记录

    最近要做微信小程序,要求接口必须备案且是https,个人小站就直接准备使用免费的SSL证书,网上搜了一圈,发现Let's Encrypt是浏览器支持比较好的. 流程: 1. 首先去服务器上安装了Let ...

  9. WSL(Windows Subsystem for Linux)--Pico Process Overview

    [转载] Windows Subsystem for Linux -- Pico Process Overview Overview This post discusses pico processe ...

  10. ARTS打卡第四周

    Algorithm 只出现一次的数字   给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用 ...