数据库
首页 > 数据库> > 17.Redis6.0新功能

17.Redis6.0新功能

作者:互联网

17.Redis6.0新功能

17.1.ACL

17.1.1.简介

Redis ACL是Access Control List(访问控制列表)的缩写,该功能允许根据可以执行的命令和可以访问的键来限制某些连接。

在Redis 5版本之前,Redis 安全规则只有密码控制 还有通过rename 来调整高危命令比如 flushdb , KEYS* , shutdown 等。Redis 6 则提供ACL的功能对用户进行更细粒度的权限控制 :
(1)接入权限:用户名和密码
(2)可以执行的命令
(3)可以操作的 KEY
参考官网:https://redis.io/topics/acl

17.1.2.命令

1、使用acl list命令展现用户权限列表
(1)数据说明
在这里插入图片描述
2、使用acl cat命令
在这里插入图片描述
(2)加参数类型名可以查看类型下具体命令
在这里插入图片描述
3、使用acl whoami命令查看当前用户
在这里插入图片描述
4、使用aclsetuser命令创建和编辑用户ACL
(1)ACL规则
下面是有效ACL规则的列表。某些规则只是用于激活或删除标志,或对用户ACL执行给定更改的单个单词。其他规则是字符前缀,它们与命令或类别名称、键模式等连接在一起。
在这里插入图片描述
在这里插入图片描述
(2)通过命令创建新用户默认权限
acl setuser user1
在这里插入图片描述
在上面的示例中,我根本没有指定任何规则。如果用户不存在,这将使用just created的默认属性来创建用户。如果用户已经存在,则上面的命令将不执行任何操作。
(3)设置有用户名、密码、ACL权限、并启用的用户
acl setuser user2 on >password ~cached:* +get
在这里插入图片描述
(4)切换用户,验证权限
在这里插入图片描述

17.2.IO多线程

17.2.1.简介

Redis6终于支撑多线程了,告别单线程了吗?
IO多线程其实指客户端交互部分的网络IO交互处理模块多线程,而非执行命令多线程。Redis6执行命令依然是单线程。

17.2.2.原理架构

Redis 6 加入多线程,但跟 Memcached 这种从 IO处理到数据访问多线程的实现模式有些差异。Redis 的多线程部分只是用来处理网络数据的读写和协议解析,执行命令仍然是单线程。之所以这么设计是不想因为多线程而变得复杂,需要去控制 key、lua、事务,LPUSH/LPOP 等等的并发问题。整体的设计大体如下:
在这里插入图片描述
另外,多线程IO默认也是不开启的,需要再配置文件中配置
io-threads-do-reads yes
io-threads 4

17.3.工具支持 Cluster

之前老版Redis想要搭集群需要单独安装ruby环境,Redis 5 将 redis-trib.rb 的功能集成到 redis-cli 。另外官方 redis-benchmark 工具开始支持 cluster 模式了,通过多线程的方式对多个分片进行压测。
在这里插入图片描述

17.4.Redis新功能持续关注

Redis6新功能还有:

标签:功能,Redis6.0,17,Redis,用户,ACL,命令,多线程,acl
来源: https://blog.csdn.net/m0_52871221/article/details/120543325