Redis

###RDB方式的优点###

RDB是一个非常紧凑的文件,它保存了某个时间点的数据集,非常适用于数据集的备份,比如你可以在每个小时报保存一下过去24小时内的数据,同时每天保存过去30天的数据,这样即使出了问题你也可以根据需求恢复到不同版本的数据集。

RDB是一个紧凑的单一文件,很方便传送到另一个远端数据中心,非常适用于灾难恢复。

RDB在保存 RDB文件时父进程唯一需要做的就是 fork出一个子进程,接下来的工作全部由子进程来做,父进程不需要再做其他 IO操作,所以 RDB持久化方式可以最大化 Redis的性能。

与AOF相比,在恢复大的数据集的时候,RDB方式会更快一些。

当 Redis需要保存 dump.rdb文件时, 服务器执行以下操作:

Redis调用forks.同时拥有父进程和子进程。

子进程将数据集写入到一个临时 RDB文件中。

当子进程完成对新 RDB文件的写入时,Redis用新 RDB文件替换原来的 RDB文件,并删除旧的 RDB文件。

这种工作方式使得 Redis可以从写时复制(copy-on-write)机制中获益。

###AOF方式的优点###

使用AOF会让你的Redis更加耐久:

你可以使用不同的 fsync策略:无 fsync、每秒 fsync、每次写的时候 fsync .使用默认的每秒 fsync策略, Redis的性能依然很好( fsync是由后台线程进行处理的,主线程会尽力处理客户端请求),一旦出现故障,你最多丢失1秒的数据。

AOF文件是一个只进行追加的日志文件,所以不需要写入seek,即使由于某些原因(磁盘空间已满,写的过程中宕机等等)未执行完整的写入命令,你也也可使用redis-check-aof工具修复这些问题。

Redis可以在 AOF文件体积变得过大时,自动地在后台对 AOF进行重写: 重写后的新 AOF文件包含了恢复当前数据集所需的最小命令集合。 整个重写操作是绝对安全的,因为 Redis在创建新 AOF文件的过程中,会继续将命令追加到现有的 AOF文件里面,即使重写过程中发生停机,现有的 AOF文件也不会丢失。 而一旦新 AOF文件创建完毕,Redis就会从旧 AOF文件切换到新 AOF文件,并开始对新 AOF文件进行追加操作。

AOF文件有序地保存了对数据库执行的所有写入操作, 这些写入操作以 Redis协议的格式保存, 因此 AOF文件的内容非常容易被人读懂, 对文件进行分析(parse)也很轻松。 导出(export) AOF文件也非常简单: 举个例子, 如果你不小心执行了 FLUSHALL命令, 但只要 AOF文件未被重写, 那么只要停止服务器, 移除 AOF文件末尾的 FLUSHALL命令, 并重启 Redis, 就可以将数据集恢复到 FLUSHALL执行之前的状态。

###save和 bgsave保存###

有的,Redis提供了save和bgsave这两种不同的保存方式,并且这两个方式在执行的时候都会调用rdbSave函数,但它们调用的方式各有不同:

save直接调用 rdbSave方法 ,阻塞 Redis主进程,直到保存完成为止。在主进程阻塞期间,服务器不能处理客户端的任何请求。

bgsave则 fork出一个子进程,子进程负责调用 rdbSave,并在保存完成之后向主进程发送信号,通知保存已完成。因为 rdbSave在子进程被调用,所以 Redis服务器在 bgsave执行期间仍然可以继续处理客户端的请求。

save是同步操作,bgsave是异步操作。

bgsave命令的使用方法和save命令的使用方法是一样的:

RDB持久化 默认开启

关闭持久化

    save ""

主动保存

    save同步

    bgsave异步

AOF持久化 默认关闭

手动开启

    appendonly yes

持久化方式配置

    appendfsync always  #每次有数据修改发生时都会写入AOF文件(安全但是费时)。

    appendfsync everysec  #每秒钟同步一次,该策略为AOF的缺省策略。

    appendfsync no  #从不同步。高效但是数据不会被持久化。

自定义AOF文件

    appendfilename "appendonly.aof"

选择方式

分析对比两种方式并做了测试后,发现这是两种不同风格的持久化方式,那么应该如何选择呢?

    对于企业级的中大型应用,如果不想牺牲数据完整性但是又希望保持高效率,那么你应该同时使用 RDB和 AOF两种方式;

    如果你不打算耗费精力在这个地方,只需要保证数据完整性,那么优先考虑使用 AOF方式;

    RDB方式非常适合大规模的数据恢复,如果业务对数据完整性和一致性要求不高,RDB是很好的选择

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 一、Redis高可用概述 在介绍Redis高可用之前,先说明一下在Redis的语境中高可用的含义。 我们知道,在w...
    空语阅读 1,596评论 0 2
  • 一、Redis持久化概述 持久化的功能:Redis是内存数据库,数据都是存储在内存中,为了避免进程退出导致数据的永...
    心似南风阅读 928评论 0 1
  • 一:快照模式 或莫过于SNAPSHOTTING模式,这个不需要反驳吧,而且你可能还知道,使用SNAPSHOTTIN...
    kevin0016阅读 627评论 0 1
  • 本文档翻译自http://redis.io/topics/persistence。 这篇文章提供了 Redis 持...
    daos阅读 693评论 0 10
  • 我的直觉告诉我,小女孩一定还在那个荒凉的房屋边! 带着疑惑和不安我开车上路。 …… 果不其然,小女孩依旧在那所破旧...
    米饭九儿阅读 275评论 0 0