【Redis】Redis6.0 新功能

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【Redis】Redis6.0 新功能

一、ACL访问控制列表

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

在 Redis 5 版本之前,Redis 安全规则只有密码控制 还有通过 rename 来调整高危命令比如 flushdb,KEYS* ,shutdown 等。Redis 6 则提供 ACL 的功能对用户进行更细粒度的权限控制 :

(1)接入权限:用户名和密码

(2)可以执行的命令

(3)可以操作的 KEY

参考官网:redis.io/topics/acl

1. 使用 acl list 命令展现用户权限列

image.png

2. 使用 acl cat 命令

(1)查看添加权限指令类别

image.png

(2)加参数类型名可以查看类型下具体命令

image.png

3. 使用 acl whoami 命令查看当前用户

image.png

4. 使用 acl setuser 命令创建和编辑用户 ACL

(1)ACL 规则

下面是有效 ACL 规则的列表,某些规则只是用于激活或删除标志,或对用户 ACL 执行给定更改的单个单词。其他规则是字符前缀,它们与命令或类别名称、键模式等连接在一起

image.png

(2)通过命令创建新用户默认权限

acl setuser user1

image.png

在上面的示例中,我根本没有指定任何规则。如果用户不存在,这将使用 just created 的默认属性来创建用户。如果用户已经存在,则上面的命令将不执行任何操作

(3)设置有用户名、密码、ACL 权限、并启用的用户


acl setuser user2 on >password ~cached:* +get # user2只允许对cached:开头的key进行get操作

image.png

(4)切换用户,验证权限

复制代码

auth 用户 密码

image.png

二、IO 多线程

1. 简介

Redis6 终于支撑多线程了,告别单线程了吗?

IO 多线程其实指客户端交互部分的网络 IO 交互处理模块多线程,而非多线程执行命令,Redis6 执行命令依然是单线程

2. 原理架构

Redis 6 加入多线程,但跟 Memcached 这种从 IO 处理到数据访问多线程的实现模式有些差异

Redis 的多线程部分只是用来处理网络数据的读写和协议解析,执行命令仍然是单线程。之所以这么设计是不想因为多线程而变得复杂,需要去控制 key、lua、事务, LPUSH/LPOP 等等的并发问题

整体的设计大体如下:

image.png

另外,多线程网络IO 默认也是不开启的,需要再配置文件redis-6379.conf中配置


io-threads-do-reads yes
io-threads 4

三、集群工具支持 Cluster

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

image.png

四、Redis6 其他新功能

  1. RESP3 新的 Redis 通信协议:优化服务端与客户端之间通信
  2. Client side caching 客户端缓存:基于 RESP3 协议实现的客户端缓存功能。为 了进一步提升缓存的性能,将客户端经常访问的数据 cache 到客户端。减少 TCP 网络 交互。
  3. Proxy 集群代理模式:Proxy 功能,让 Cluster 拥有像单实例一样的接入方式, 降低大家使用 cluster 的门槛。不过需要注意的是代理不改变 Cluster 的功能限制,不 支持的命令还是不会支持,比如跨 slot 的多 Key 操作。
  4. Modules API Redis 6 中模块 API 开发进展非常大,因为 Redis Labs 为了开发复杂的功能,从一 开始就用上 Redis 模块。Redis 可以变成一个框架,利用 Modules 来构建不同系统,而 不需要从头开始写然后还要 BSD 许可。Redis 一开始就是一个向编写各种系统开放的 平台


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
6月前
|
缓存 NoSQL API
redis6新功能
redis6新功能
|
4月前
|
NoSQL Cloud Native Redis
|
6月前
|
NoSQL 数据处理 调度
【Redis技术专区】「原理分析」探讨Redis6.0为何需要启用多线程
在Redis 6.0版本中,引入了多线程技术,这是为了进一步提高Redis的性能和并发处理能力。通过启用多线程,Redis能够同时处理多个客户端请求,有效地利用多核处理器资源,提高系统的吞吐量和响应速度。
391 1
【Redis技术专区】「原理分析」探讨Redis6.0为何需要启用多线程
|
NoSQL 网络协议 Redis
Redis学习笔记-高性能IO模型&Redis6.0多线程
Redis学习笔记-高性能IO模型&Redis6.0多线程
133 0
|
缓存 编解码 NoSQL
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?
云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! Redis 6.0.1 于 2020 年 5 月 2 日正式发布了,如 Redis 作者 antirez 所说,这是迄今为止最“企业”化的版本,也是有史以来改动最大的一个 Redis 版本,同时也是参与开发人数最多的一个版本。
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?
|
NoSQL Redis 存储
5分钟带你了解Redis 5.0新功能 内含重量级特性解读
Redis是目前最流行的KV缓存数据库,它简单易用,安全稳定,在互联网行业有着非常广泛的应用。
2777 0
|
缓存 编解码 NoSQL
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?(下)
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?
211 0
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?(下)
|
缓存 NoSQL API
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?(上)
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?
175 0
Redis 6.0 正式版终于发布了!除了多线程还有什么新功能?(上)
|
存储 缓存 运维
2020年 Redis 这五大新功能你最期待哪一个?
Redis 是世界上最流行的 KV 缓存数据库,2009年诞生至今,已发展超过十个年头,2020年,Redis可以为我们带来什么惊喜呢?
12428 0
2020年 Redis 这五大新功能你最期待哪一个?
|
NoSQL Redis
redis-4.0新功能介绍
阿里云redis-4.0的新特性介绍
5245 0