Redis

概述:

1、内部数据结构:sds、字典、redisObject

2、Redis数据类型

3、内部运行机制:数据库结构、数据库建过期及清除、Redis事务

4、持久化:RDB、AOF(Redis协议)

5、性能:慢查询日志、数据淘汰策略

6、Redis高可用发展:主从、哨兵、集群

7、集群方案:

  官方集群Redis Cluster:服务端集群

  Redis Sharding集群:客户端集群

  代理中间件:增加代理层,如twemproxy

8、memcache对比

9、redis数据结构的应用场景:

http://m635674608.iteye.com/blog/2239012

参考:

总览:    http://redisbook.readthedocs.io/en/latest/index.html#

持久化:  https://redis.io/topics/persistence

集群方案:https://www.zhihu.com/question/21419897/answer/89771396

          http://www.jianshu.com/p/dbc62ed27f03

memcache:https://www.qcloud.com/community/article/164816001481011841?fromSource=gwzcw.93414.93414.93414

常见问题:https://my.oschina.net/u/1988057/blog/860310

          http://www.jianshu.com/p/9363e5b69c27

持久化

@see https://redis.io/topics/persistence

Redis Persistence

Redis provides a different range of persistence options:

The RDB persistence performs point-in-time snapshots of your dataset at specified intervals.

The AOF persistence logs every write operation received by the server, that will be played again at server startup, reconstructing the original dataset.

If you wish, you can disable persistence at all, if you want your data to just exist as long as the server is running.

It is possible to combine both AOF and RDB in the same instance. Notice that, in this case, when Redis restarts the AOF file will be used to reconstruct the original dataset since it is guaranteed to be the most complete.

RDB:以指定的时间间隔,持久化该时间点的数据快照。

AOF:为服务器接收到的每个写入操作记录日志,当服务器重启时将会被重新读入,重建原始数据。

在同一个实例中,可采用AOF和RDB结合的方式。在这种情况下,当Redis重启时,将使用AOF文件来重新构建数据,因为AOF更能保证数据的完整性。

另外,Redis 可以完全禁用持久化,仅仅运行在内存中。

RDB优点

1、RDB是Redis数据是在某个时间点上,持久化的单个压缩文件。RDB文件是Redis数据的完美备份。

2、RDB非常适合容灾恢复,可以将单个压缩文件发送至远程数据中心

3、RDB可以最大化Redis持久化性能,主进程只需要持续地fork一个子进程,然后将剩下工作交给子进程去完成。主进程不需要参与硬盘的IO操作。

RDB缺点

1、RDB 当发生Redis突然宕机等突发情况时,数据丢失概率较大。RDB是以固定时间间隔来创建快照的,当Redis突然宕机时,这个时间段内的数据将会丢失。

2、RDB 经常需要fork一个子进程来写磁盘。如果数据很大或CPU性能不佳时,fork将会变得非常耗时,可能造成服务端暂停响应客户端几毫秒甚至一秒。AOF也需要fork,但是可以调整写日志的频率,只要不影响持久化即可。

AOF优点

1、使用AOF,Redis更加可靠。默认的同步策略(AOF的记录日志操作又叫同步)每秒钟同步一次(同步由后台线程执行),最多也仅仅只会丢失一秒钟的数据。

2、AOF日志是追加日志的形式,因此即使发生断电等事故也不会产生腐败问题。即使由于某种原因日志以写入一半的命令结束,也可由redis-check-aof工具轻松修复。

3、当Rdis数据增长的非常大时,Redis可以在后台自动重写AOF。重写是完全安全的,当Redis继续向旧文件写入时,同时会创建一个新文件,一旦新文件准备好,Redis就会切换并将日志追加至新文件中。

4、AOF是一个包含所有操作的日志文件,易于理解和解析。可以轻松的导出一个AOF文件。假设错误的使用了FLUSHALL命令,如果在期间没有发生日志重写,只需要停止服务端并删除最近的命令,然后重启Redis即可。

AOF缺点

1、AOF文件通常比同样数据的RDB文件要大。

2、AOF根据具体的同步策略,可能会比RDB更慢。通常every second同步策略的性能仍然很高,假如不使用同步策略,则在高负载下的性能应该都可以与RDB持平。

  不过当在巨大的写入负载的情况下,还是RDB更能保证在某个最大延迟以内。

3、一些特定的命令,曾经发生过很少的BUG,导致AOF在重新加载时不能再现完全相同的数据。而这RDB是几乎不可能发生的。

选择:

1、通常情况下,应该这两种持久化方式并用来达到如同PostgreSQL 这样的数据安全级别。

2、如果你可以承受发灾难时可能造成的若干分钟的数据丢失,那么可以简单的仅仅使用RDB

3、也有许多用户仅仅使用AOF,并不鼓励这种方式。每隔若干时间段的RDB数据快照是个非常的数据库备份策略,如果AOF发生BUG,支持更快的重启。

总结:综上所述,未来我们最终可能会将AOF和RDB统一到单一持久性模型(长期计划)。

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

推荐阅读更多精彩内容