一,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. C# 连接/查询Jira

    查询jira数据,如果是前端,可以按照如下格式直接访问,获取数据 http://jira.company.com/rest/api/2/search?jql=project = REM AND res ...

  2. 1.常用turtle功能函数

    #turtle常用命令汇总,括号中的参数仅仅作为举例使用,可根据需要修改 #设置画面背景色 turtle.bgcolor("black") #设置窗口大小和在屏幕上的坐标 turt ...

  3. CSS中盒模型的理解

    今天突然看到一篇关于CSS中盒模型的文章,忽然觉得自己竟然遗忘了很多小的地方,所以写一篇文章来记忆一下 (摘抄于千与千寻写的CSS盒子模型理解,并在自己基础上添加了一些东西,希望更完善,对大家有帮助) ...

  4. NextCloud前端支持播放mov文件

    默认情况下,NextCloud网盘是不支持播放 .mov文件的. 通过修改前端代码就可以实现. 如下 1 找到 apps/files_videoplayer/js/viewer.js 文件 2 搜索 ...

  5. ButterKnife的使用详解

    ButterKnife的使用详解 1,概述: ButterKnife则是注解中相对简单易懂的很不错的开源框架. ButterKnife是目前常用的一种依托Java注解机制实现辅助代码生成的框架:用到了 ...

  6. Java版 人脸识别SDK demo

    虹软人脸识别SDK之Java版,支持SDK 1.1+,以及当前最新版本2.0,滴滴,抓紧上车! 前言 由于业务需求,最近跟人脸识别杠上了,本以为虹软提供的SDK是那种面向开发语言的,结果是一堆dll· ...

  7. MySQL随笔(1)

    mysql是一种关系型数据库,和SQL ,oracle一样是较为常用的关系型数据库,属于oracle旗下的产品,在web应用方面,MySQL是最好的RDBMS(relational database ...

  8. powershell-将powershell脚本排到JOB

    Program/script下填写“Powershell”,表示这个脚本会在powershell环境下运行 Add arguments(optional)填写脚本绝对路径名称 Start in(Opt ...

  9. gcc/g++ 编译参数

    1, -E(大写),预处理 例子:gcc -E test.cpp -o test.i 预处理,把程序里的#开头的替换掉,比如#include,然后生成test.i 2,-P(大写),去掉预处理生成的杂 ...

  10. Visual Studio Code自定义快捷键(eclipse习惯)

    左下角设置按钮 -> Keyboard Shortcuts -> keybindings.json. [ { "key": "alt+/", &qu ...