2022 RedisDays 内容揭秘
上个月,Redis举办了3场线上会议,分别介绍了即将正式发布的Redis 7中包括的重要更新的内容,还有Redis完全重写的RedisJSON 2.0模块,和新发布的Redis Stack模块。除此之外,在此次线上会议中还介绍了现代化的软件架构与Redis是如何紧密结合在一起,例如Redis与Machine Learning或者人工智能的结合。下面让我们来具体看一下在会议中提到的具体内容吧。下面我们来看一个具体的例子:
首先,让我们来看一下Redis 7提供的新特性
1、Redis Functions: 在Redis 7.0中作为Lua脚本的升级内容
在2012年发布的Redis2.6中,Redis引入了Lua脚本这个概念。Lua脚本概念的引入使得Redis中的数据与客户的应用程序结合的更加紧密,但是不可否则,Lua脚本依然有它的局限性:Lua脚本是存在于客户端应用程序中的,一旦客户端应用重新启动,那么Lua脚本需要重新加载,这样就增加了对客户端应用程序的代码量与程序员维护程序的成本。为了解决这些问题,Redis 7.0加入了Redis Functions这个概念,Redis Functions可支持持久化,可复制,并且在节点重启之后可以直接从server端读取,并且还提供未来多种语言的API支持(目前只支持Lua)。下面我们来看一个具体的例子:

图一:是一个名字为myscript.lua 的Lua脚本文件
我们可以看到当脚本成功执行,server端的log显示:Execution started 和Execution ended。

图二:是这个脚本文件在客户端运行的情况
当server被重启后,这个Lua脚本如果不重新加载,那么它不会被执行,会显示错误信息。

图三:显示信息
那么下面我们来看一下如果是Redis Functions,运行的情况是什么样的。首先让我们来看一下Lua脚本和Redis Functions脚本的共同点和区别。下图是一个名为mylib.lua的Redis Functions脚本与之前的Lua脚本的一个对比。我们可以看到,唯一的不同是在Redis Functions中执行了一条语句:
redis.register_function(“hgetset”, hgetset);

图四:前后对比
我们看到客户端首先运行: redis-cli –x FUNCTION LOAD Lua mylib 将这个mylib加载进Redis 服务器端,然后调用redis-cli FCALL hgetset 1 myhash myfield “some other value” 去调用这个函数,最后我们可以看到成功的被执行了。

在server被重新启动之后,如果我们直接执行redis-ci FCALL …. 去调用这个函数,mylib中的函数依然可以执行成功,而不需要像Lua脚本那样重新加载。

2、ACL Selectors: 对于Redis 6.0 ACL功能的扩展(V1),可以支持更丰富和更方便的权限设置
在Redis 7 之前的ACL功能具有很多限制:例如一个用户不能对不同的键设置不同的权限(permissions);或者用户也不能对不同的键赋予不同的读写权限。在Redis 7中的ACL V2中,这些方面得到了进一步的改善:新增加了一个selector的概念,这个概念是将一系列的权限规则放在一起作为一个整体来执行(Selectors are a collection of authorization rules that are evaluated as a group), 并且用户可以执行命名以root权限执行或者作为某一个selector来执行(A user can execute a command if either the root permission or any selector authorizes the commands)。另外,在ACL V2中,Redis 新增了用户对键(key based)的权限控制能力,下面我们来看一个具体的例子:
基于Selector的例子,我们可以看到基于MADELYN用户,它对于itamar_q 是有LPOP操作权限而没有LPUSH操作权限的,但是对于madelyn_q是有LPUSH操作权限的。

基于key based 权限的例子

3、在集群方面
增加了对分片的Pub/Sub支持,并且还增加了对主机名的支持。
4、在底层数据结构中
使用listpacks替换了ziplists,并且使用了RDB 10的格式。
5、对于AOF文件,使用了多AOF机制
使得在重写过程中使用更少的内存和占用更低的I/O;第二个特点是在AOF中增加了每个键值对所对应的时间戳,为之后的Redis版本提供回滚和恢复提供了很好的支持。
RedisJSON 2.0
RedisJSON 2.0是由RUST完全重写的,它比上一个版本提供了更强的性能,更好的稳定性和更低的内存占用率。同时,RedisJSON2.0 对文档中的特定内容提供了JSONPath的语法支持。新的版本具有以下新特点:1.支持文档中子元素(sub-element)的更新。这种能力基于使用了JSON 数据交换格式(ECMA 404)作为元数据类型对子元素执行原子化的更新操作,其结果是大大提高的开发者的效率并且加快了应用程序的相应速度2.RediSearch可以支持索引(index),可以在JSON文档中进行全文查找3.新版本不但对大多数流行的主流语言(JavaScript, Python, Java C#)和平台(Spring, ASP.NET, Node.js, DJango)提供支持,而且还对RedisInsight提供良好的GUI和入门指导下面提供一个具体的例子来说明一下以上提到的特点:

更新user = 1 的score部分从5到100

更新user = 1 的内嵌的profile的属性name为Sue

为user=1的属性friends数组增加user:3

如果想了解更多关于RedisJSON2.0的内容,可以查看链接:
https://redis.com/press/redisjson-2-0-serves-as-fast-flexible-document-database/
Redis Stack
在此次RedisDay中,Redis官方几乎花了2个小时全方面的介绍了Redis Stack,并列举了几个具体的例子来说明Redis Stack是如何与应用程序结合的。
事实上,Redis Stack一个Redis对于数据模型和处理引擎的扩展模块。它支持可查询的JSON文档,基于时间序列的数据的操作等功能。并且,Redis Stack还包括了RedisInsight,一个Redis的可视化工具。
如果想了解更多的关于Redis Stack的内容,可以查看链接(https://redis.io/docs/stack/)及我们后续关于Redis Stack专题的博客。
除了以上内容,在这3天的RedisDay中还介绍了一些Redis与人工智能,机器学习相关的应用与API,有感兴趣的各位读者可以登录Redis网站去观看相关视频:
https://redis.com/redisdays/,谢谢您继续关注我们关于Redis的相关文章。
*注:本文所有图片和例子都取自于RedisDays中的视频,感谢Redis 开源社区所有贡献者对Redis所作的贡献。
2022 RedisDays 内容揭秘的更多相关文章
- 产品揭秘】来也Lead 2022产品亮点解读-RPA学习天地
2022年4月26日,来也举行新品发布会.作为技术人员,花里胡哨的我且不说,我且说技术相关.整体架构"概念"整个平台覆盖了智能自动化的全生命周期包含:业务理解.流程创建.随处运行. ...
- ASP.NET Core 6框架揭秘实例演示[34]:缓存整个响应内容
我们利用ASP.NET开发的大部分API都是为了对外提供资源,对于不易变化的资源内容,针对某个维度对其实施缓存可以很好地提供应用的性能.<内存缓存与分布式缓存的使用>介绍的两种缓存框架(本 ...
- 揭秘华为云GaussDB(for Influx)最佳实践:hint查询
摘要:GaussDB(for Influx)通过提供hint功能,在单时间线的查询场景下,性能有大幅度的提升,能有效满足客户某些特定场景的查询需求. 本文分享自华为云社区<华为云GaussDB( ...
- 2022年Web前端开发流程和学习路线(详尽版)
前言 前端侧重于人机交互和用户体验,后端侧重于业务逻辑和大规模数据处理.理论上,面向用户的产品里,所有问题(包括产品.设计.后端.甚至看不见的问题)的表现形式,都会暴露在前端,而只有部分问题(数据问题 ...
- Syscan360会议胸牌破解揭秘
Syscan360会议胸牌破解揭秘 背景 有幸参加今年11月份的上海Syscan360安全会议,会议期间有一个亮点就是360的独角兽团队设计了一款电子badge(胸牌)供参加人员进行破解尝试,类似于美 ...
- CI Weekly #9 | 揭秘阿里 Docker 化实践之路
2017年悄然而至,对 flow.ci 你有什么新的期待呢?新的一年,flow.ci会越来越强大好用,希望继续得到你的支持与反馈.最近,我们做了如下的「功能优化」与「问题修复」,看看有没有你想要的: ...
- js瀑布流 原理实现揭秘 javascript 原生实现
web,js瀑布流揭秘 瀑布流再很久之前流行,可能如我一样入行晚的 ,可能就没有机会去使用.但是这个技术终究是个挺炫酷的东西,花了一个上午来研究,用原生js实现了一个,下面会附上源码,供大家解读. 说 ...
- 【直播】APP全量混淆和瘦身技术揭秘
[直播]APP全量混淆和瘦身技术揭秘 近些年来移动APP数量呈现爆炸式的增长,黑产也从原来的PC端转移到了移动端,通过逆向手段造成数据泄漏.源码被盗.APP被山寨.破解后注入病毒或广告现象让用户苦不堪 ...
- ASP.NET Core中的依赖注入(5): ServiceProvider实现揭秘 【总体设计 】
本系列前面的文章我们主要以编程的角度对ASP.NET Core的依赖注入系统进行了详细的介绍,如果读者朋友们对这些内容具有深刻的理解,我相信你们已经可以正确是使用这些与依赖注入相关的API了.如果你还 ...
- 新作《ASP.NET MVC 5框架揭秘》正式出版
ASP.NET MVC是一个建立在ASP.NET平台上基于MVC模式的Web开发框架,它提供了一种与Web Form完全不同的开发方式.ASP.NET Web Form借鉴了Windows Form基 ...
随机推荐
- SpringBoot项目统一处理返回值和异常
目录 简介 前期准备 统一封装报文 统一异常处理 自定义异常信息 简介 当使用SpringBoot开发Web项目的API时,为了与前端更好地通信,通常会约定好接口的响应格式.例如,以下是一个JSON格 ...
- GC的前置工作,聊聊GC是如何快速枚举根节点的
本文已收录至GitHub,推荐阅读 Java随想录 微信公众号:Java随想录 原创不易,注重版权.转载请注明原作者和原文链接 目录 什么是根节点枚举 根节点枚举存在的问题 如何解决根节点枚举的问题 ...
- DDD实践:实现基于快照机制的变更追踪
王有志,一个分享硬核Java技术的互金摸鱼侠 加入Java人的提桶跑路群:共同富裕的Java人 去年我们在重构项目中落地了DDD,当时花了点时间研究了下阿里巴巴大淘宝技术发布的<阿里技术专家详解 ...
- K8S集群中使用JD KMS服务对敏感数据安全加密
基本概念 KMS,Key Management Service,即密钥管理服务,在K8S集群中,以驱动和插件的形式启用对Secret,Configmap进行加密.以保护敏感数据, 驱动和插件需要使用者 ...
- Python自定义终端命令
在python中自定义一个终端命令 这里我们想要将一个csv文件中的数据导入到数据库中,就可以定义一个终端命令,直接一行命令就可以将我们文件中的数据导入到数据库中,特别的简单 首先,我们先创建一个py ...
- Codeforces Round div.2 C
Smiling & Weeping ----我对姑娘的喜欢,何止钟意二字 题目链接:Problem - C - Codeforces 自我分析:我感觉这是一道很有意义的题目,可以帮我们更好的理 ...
- 简化车辆登记流程:利用腾讯云OCR实现自动化信息识别
项目中有一块,需要用到上传车牌车牌号到系统里,用了下腾讯云的ocr车牌号识别做了个小功能.通过腾讯云的orc识别,将车牌号录入到后台. 一,首先我们需要登录到腾讯云,然后搜索一下orc或者车牌号 ...
- 《Docker到Kubernetes容器运维实战》简介
#好书推荐##好书奇遇季#<Docker到Kubernetes容器运维实战>已经出版.本书帮助读者系统掌握Docker与K8s运维技能. 本书内容 本书分两部分系统介绍Docker与K ...
- java中有哪些并发的List?只知道一种的就太逊了
java中有很多list,但是原生支持并发的并不多,我们在多线程的环境中如果想同时操作同一个list的时候,就涉及到了一个并发的过程,这时候我们就需要选择自带有并发属性的list,那么java中的并发 ...
- 「tjoi 2018」智力竞赛
link. 这题数据应该蛮水的,直接把大于二分值的点去掉实际上应该是有问题的.然而题解区里都写的是这种做法,所以这里主要对如何处理大于二分值的点做分析. 注意这里大于二分值的点的意义是「可以走,但走了 ...