antirez:Redis6真的来了

12月20号,Redis发布了Redis6-rc1版本,作者antirez也在自己的博客中宣布了这一消息,并对Redis6版本做了一些介绍,以下是译文。

没错,新版本的Redis已经到了候选发布状态(RC版),几个月后,你就可以在各大应用市场看到新版本的Redis了。我想这大概是迄今为止,Redis最接近“企业级”应用的一个版本了,有趣的是,在这之前我花了很长时间来理解什么是企业级应用。我认为我并不喜欢这个词,但是它还是有一些意义的。现在Redis可以说是无处不在,并且仍然能够“缩小规模”:你可以直接下载它,在30秒内完成编译,然后在不需要进行任何配置的情况下启动它。但是无处不在意味着加密和ACL之类的环境也是必须要支持的,因此Redis必须要感谢我,尽管我极力追求简单性。

有趣的是,Redis ACL虽然是以一种武断的方式进行添加,但它几乎与你在其他系统中看到的都不一样,对SSL的支持也是经过了数次迭代,以达到最终使用最有意义的想法的目的。从让核心功能尽可能简洁的角度来看,我对这些改动还是很满意的。

Redis6为我们带来的不仅仅是ACLs和SSL,据我所知,这是Redis发行的功能最多,也是参与人数最多的一个版本了。都有谁为Redis6做出了贡献呢?我生成了一个贡献者列表(我知道这个列表很烂,我只是简单生成了一下),他们至少有两个commit,并且不包括合并提交。另外,由于我不断在这里或那里修复许多小东西,因此我的提交次数可能会远超他人。

685  antirez
81  zhaozhao.zz
76  Oran Agra
51  artix
28  Madelyn Olson
27  Yossi Gottlieb
15  David Carlier
14  Guy Benoish
14  Guy Korland
13  Itamar Haber
9  Angus Pearson
8  WuYunlong
8  yongman
7  vattezhang
7  Chris Lamb
5  Dvir Volk
5  meir@redislabs.com
5  chendianqiang
5  John Sully
4  dejun.xdj
4  Daniel Dai
4  Johannes Truschnigg
4  swilly22
3  Bruce Merry
3  filipecosta90
3  youjiali1995
2  James Rouzier
2  Andrey Bugaevskiy
2  Brad Solomon
2  Hamid Alaei
2  Michael Chaten
2  Steve Webster
2  Wander Hillen
2  Weiliang Li
2  Yuan Zhou
2  charsyam
2  hujie
2  jem
2  shenlongxing
2  valentino
2  zhudacai 00228490
2  喜欢兰花山丘

感谢上面各位的贡献,这是一次很棒的团队合作。

下面的列表是新功能列表:

  • 很多新的模块API
  • 更好的过期周期
  • SSL
  • ACLs
  • RESP3
  • 客户端缓存
  • 线程I/O
  • 副本上的无盘复制
  • Redis-benchmark支持集群+Redis-cli的改进
  • 系统支持重写
  • Redis Cluster代理与Redis6一起发布(不同仓库)
  • Redis 6发布了Disque模块(不同仓库)

如你所见,有很多比较大的改动,接下来我会选择其中几个进行介绍。

RESP3

10年之后,我们需要一个新的协议,我在这篇博客中进行了广泛的讨论:http://antirez.com/news/125,但我随后改变了主意,所以RESP3在Redis6中是“选择加入”。连接最开始是RESP2模式,只有当你使用新的HELLO命令握手时,你才会进入新的协议模式。

我们为什么需要一个新的协议呢?因为旧的语义不够清晰。RESP3中还有一些其他功能,但主要思想是能够直接从Redis返回复杂数据类型,而客户端不必知道要转换为哪种类型的数组,或者返回的数字是否能够转换成布尔值等等。

由于RESP3不是仅有的协议,所以它的使用速度比预期要慢一些,但这也许不是一件坏事,因为这样我们就有足够的时间来进行适应和调整。

ACLs

对Redis ACLs最好对介绍就是ACL文档本身(https://redis.io/topics/acl),即使它可能需要进行一些更新以匹配最近对修改。我在这里更想讨论一下使用它的动机。Redis需要ACLs是因为人们需要在更广泛的使用ACLs,以达到更好的控制客户端可以做的某些操作。另一个增加ACLs的主要原因是进行隔离,以保护数据免受应用程序错误的侵害。如果你的工作节点只能做BRPOPLPUSH操作,那么新的开发人员使用FLUSHALL的机会就比较少,也能够降低生产环境执行FLUSHALL的可能性。

在Redis中ACLs的操作都是免费的,因为如果你不用它们,性能上就不会受影响,毕竟这部分开销无法衡量。我想这是最好的处理方法了,值得一提的是,我们现在为ACL提供了Redis模块接口,因此你可以编写自定义身份验证方法。

SSL

现在是2019年,马上要到2020年了,因此有一些新的规则。唯一的问题就是如何正确执行,正确执行的前提是错误执行并理解其局限性,然后对Redis连接进行抽象以正确执行。这项工作是在完全没有我的帮助下进行的,这也体现了Redis开发过程的改变。

客户端缓存

关于客户端缓存,我写了一篇博客(http://antirez.com/news/130),然而我认为这是Redis6最不成熟的功能。没错,服务器可以协助你在客户端缓存,这看起来很酷,但我想要在Redis6 GA版本出来之前对这个功能进行进一步优化。尤其是增加一种新的模式,在这个模式下,服务器不维护客户端的状态或者尽量少的维护客户端的状态,更多使用消息进行交互。而且,现在无法将某些“cache slots”的过期消息合并成一个。这是一个不错的想法,我们将在一月份着重做这部分功能。

Disque成为一个模块

最终,我做到了(https://github.com/antirez/disque-module),我对这个结果非常满意。

Disque作为一个模块确实显示的Redis模块系统的强大。集群消息总线API,能够阻止和恢复客户端,计时器,模块私有数据的AOF和RDB控制。如果你还不知道什么是Disque,可以去看一下这个仓库的README。

集群代理

我的同事Fabio在这个工作中花费了几个月的时间:https://github.com/artix75/redis-cluster-proxy

我想看到这个功能已经很多年了,当主题是Redis集群支持时,客户端的需要进行的操作总是很分散,现在我们有了代理(还在进行中),就可以做很多有趣的事情了。最主要的功能是为客户端抽象Redis集群,就像它们正在与单个实例通信一样。另一个功能就是至少在简单且客户端仅使用简单命令和功能时执行多路复用。当要阻止或执行事务时,代理为客户端分配一组不同的连接。代理也是完全线程级的,所以让大部分CPU时间花在I/O上,这是一种最大化CPU使用率的好方法。你可以查看README文件,然后试一试这个功能。

Modules

Redis6的模块API完全是一个新的等级了。这是Redis发展最快的部分之一,因为我们从最开始就使用模块系统来开发非常复杂的东西,而不仅仅是琐碎的示例。前端时间,我启动了Disque端口,这也促使我为模块系统带来新功能。现在,你可以把Redis看成一个框架,可以讲系统作为模块进行编写,避免从头造轮子,同时也可以获得BSD许可,Redis实际上是一个可以用来编写系统的开放平台。

内部

Redis内部有非常多的优化:复制命令的方式发生了很大变化,过期使用了另一种算法,该算法更快且缓存更明显。

Status和ETA

现在我们已经有了RC1,我希望在3月末,最晚5月,你就可以看到GA版本准备就绪。

现在,Redis6绝对是可测试的,并且遇到错误的机会很小。但它包含了大量的代码更改,并且新功能由新的代码组成,也从没有人在生产环境中运行过这些代码。所以如果你找到了bug,请以最好的方式描述一下发生的情况并报告给我们。

感谢所有人为该版本做出贡献的人和在接下来几个月中帮助我们维护它处于稳定状态的人。

啊,我差点忘了,这是第6版的LOLWUT命令交互图:

lolwut6

每次运行都会随机生成不同的景观。

博客原文地址

http://antirez.com/news/131

译者注

正如作者所说,Redis6带来了很多新的功能。刚发布的版本肯定不能拿到线上去玩,但是自己折腾一下,提前感受一下也不错。特别是RESP3和客户端缓存都是我比较期待的。另外还有新的过期算法,这个之前没怎么听说,也值得研究一下。不说了,我先下为敬。

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

推荐阅读更多精彩内容