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所作的贡献。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/225460.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

pyside6详细笔记

文章目录 主要模组简介绍安装与环境配置安装配置QtDesignerPyUICPyRCC基础了解元对象系统对象模型重要的类Qt 对象:身份?值?对象树与所有状态概述QObjects 的构造/销毁顺序继承关系图Qt 命名空间模块简介QWidget窗口的创建在PyQt中使用qrc/rcc资源系统Qt 资源系统简介qrc 文件…

从Java8升级到Java17,特色优化点

从Java8升级到Java17,特色优化点 一、局部变量类型推断二、switch表达式三、文本块四、Records五、模式匹配instanceof六、密封类七、NullPointerException 从Java 8 到 Java 20,Java 已经走过了漫长的道路,自 Java 8 以来,Java 生…

预赛->省赛->国赛 我的全国软件测试大赛之旅

学习推荐 Web 功能测试:Javaselenium3 web自动化测试实战 性能测试:看慕测官方的视频,这里会用就行,不用学太多 自己根据视频写的:Web自动测试常用代码(Java版) Web没啥难的,主要拼手速,其…

出错:I/O文件读取JAVA

I/O文件读取 /** author:xiaowang* date:2023/12/6* demand:读取java1班的数据* * */ package homework;import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException;public class FileReadTest {public static void main(String[] args) …

Windows系统上如何搭建Linux操作系统

一、准备工作 1,VMware安装包 2,Centos IOS镜像 3,finalshell安装包 阿里云盘下载地址: https://www.alipan.com/s/uSQsWn15E3W 二,VMware安装 1,新建虚拟机 2,选择下一步 3,…

小航助学题库白名单竞赛考级蓝桥杯等考scratch(14级)(含题库教师学生账号)

需要在线模拟训练的题库账号请点击 小航助学编程在线模拟试卷系统(含题库答题软件账号) 需要在线模拟训练的题库账号请点击 小航助学编程在线模拟试卷系统(含题库答题软件账号)

每日一题 1466. 重新规划路线(树,DFS)

根据 connections 建立无向树从 0 开始深搜,每次调用 dfs 时判断路径方向是否正确 class Solution:def minReorder(self, n: int, connections: List[List[int]]) -> int:to defaultdict(set)edge defaultdict(list)for con in connections:edge[con[0]].appe…

Numpy 实现ID3决策树

Numpy 实现ID3决策树 # 定义节点类 二叉树 class Node:def __init__(self, rootTrue, labelNone, feature_nameNone, featureNone):self.root rootself.label labelself.feature_name feature_nameself.feature featureself.tree {}self.result {label:: self.label,fea…

HarmonyOS学习--TypeScript语言学习(一)

注意:这只是我学习的笔记!!! 注意:这只是我学习的笔记!!! 注意:这只是我学习的笔记!!! 本章目录如下: 一、TypeScript语言…

汽车防爆膜行业研究:中国发展前景及市场投资分析

随着汽车保有量的不断增长,汽车的维修和保养等服务市场规模也会快速提升。业内人士表示,今年以来,越来越多的企业开始发力这一市场,汽车后市场的竞争区域也从大中城市向县域城市下沉。 防爆膜就是在车的玻璃上安装一层保护膜&…

各大期刊网址

1.NeurIPS,全称Annual Conference on Neural Information Processing Systems, 是机器学习领域的顶级会议,与ICML,ICLR并称为机器学习领域难度最大,水平最高,影响力最强的会议! NeurIPS是CCF 推…

Android 背景边框集合

效果图 代码 <?xml version"1.0" encoding"utf-8"?> <shape xmlns:android"http://schemas.android.com/apk/res/android" android:shape"rectangle"><solid android:color"#ffffff" /><stroke and…

Doris 编译报错 Error: flex version (2.5.37) must be greater than or equal to 2.6.0

Doris 编译过程报错 Error: flex version (2.5.37) must be greater than or equal to 2.6.0yum update flex 不生效 下载flex 安装包 https://github.com/westes/flex/releases解压 tar -xvf flex-2.6.4.tar

java优雅写法01 -业务判断并断言-Assert工具类

断言的理解: 断言他满足条件不抛异常; 不满足断言时产生异常&#xff1b; 业务需求&#xff1a;判断某个查询对象为空&#xff0c;直接返回错误信息 常见写法&#xff1a; if (ObjectUtil.isNull(object)){ return XXXX }Assert 写法 这句代码的意思是 如果对象为空就提示并返…

你了解架构图吗?

技术界的扛把子架构图&#xff0c;你了解吗&#xff1f;今天我们就来聊聊它 什么是架构图呢&#xff1f; 系统架构是概念的体现&#xff0c;是对物/信息的功能与形式元素之间的对应情况所做的分配&#xff0c;是对元素之间的关系以及元素同周边环境之间的关系所做的定义。 架构…

微信小程序访问不了阿里云oss图片链接解决办法

以下都有可能导致访问不了oss图片 1.小程序没有加访问白名单 这个需要前端搞,加上白名单,如果是域名加域名白名单,ip的话加ip白名单 2.阿里云设置域名白名单 打开bucket列表,选择对应的bucket 配置这个白名单,配置好以后,开发者工具可以预览了,手机端预览不了,查看自己的路…

[AbutionGraph开发文档]时序图谱数据库-流式图计算

文档地址&#xff1a;https://thutmose.gitee.io/abution-graph AbutionGraph是一款端到端数据实时分析的图谱数据库&#xff0c;实时(写入实时、决策分析实时、流式图计算实时)&#xff1a; 基于历史数据构建的指标模型实时查询&#xff1b;接入流式数据并实时更新业务指标&a…

[足式机器人]Part2 Dr. CAN学习笔记-数学基础Ch0-6复数Complex Number

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;DR_CAN Dr. CAN学习笔记-数学基础Ch0-6复数Complex Number x 2 − 2 x 2 0 ⇒ x 1 i x^2-2x20\Rightarrow x1\pm i x2−2x20⇒x1i 代数表达&#xff1a; z a b i , R e ( z ) a , I m ( z ) b zabi,\mathrm{Re}…

【ARM Coresight 系列 2 文章 -- Trace32 对 APBIC 地址的配置 介绍】

文章目录 APBIC RomtableAPBIC Romtable 图 1 APBIC 网络图 如上图所示,如果想通过Trace32/DS-5 去访问 AP, 这个时候需要怎么做呢?可以看到 APBIC 中ROMTABLE 中 APB-AP 的偏移是0x00200000,所以 APB-AP的基地址为 0x2b000000 + 0x00200000,又从 APB-AP 的romtable 中可以…

基于ssm在线云音乐系统的设计与实现论文

摘 要 随着移动互联网时代的发展&#xff0c;网络的使用越来越普及&#xff0c;用户在获取和存储信息方面也会有激动人心的时刻。音乐也将慢慢融入人们的生活中。影响和改变我们的生活。随着当今各种流行音乐的流行&#xff0c;人们在日常生活中经常会用到的就是在线云音乐系统…