• Redis:19-Redis6新特性


    说明:写笔记时Redis已经更新到7.0.5了,为什么还要写Redis6新特性,仅做个笔记。Redis7新特性就百度吧。

    一、ACL

    1、ACL简介

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

    Redis 6 则提供ACL的功能对用户进行更细的权限控制 :
    (1)接入权限:用户名和密码
    (2)可以执行的命令
    (3)可以操作的 KEY

    ACL相关介绍:https://redis.io/docs/manual/security/acl/

    2、ACL命令

    (1)使用acl list命令展现用户权限列表

    acl list
    
    • 1

    在这里插入图片描述

    (2)使用acl cat命令可查看具体的操作命令有哪些

    acl cat
    
    • 1

    在这里插入图片描述

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

    acl whoami
    
    • 1

    在这里插入图片描述

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

    acl setuser
    
    • 1

    在这里插入图片描述

    二、IO多线程

    其实Redis还是单线程+IO多路复用

    1、IO多线程简介

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

    2、原理架构

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

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

    另外,多线程IO默认也是不开启的,需要再配置文件中配置

    io-threads-do-reads  yes 
    io-threads 4
    
    • 1
    • 2

    在这里插入图片描述

    三、工具支持 Cluster

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

    四、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许可。

  • 相关阅读:
    学习DiscoDiffusion的最基础操作
    java Stream操作
    JavaList集合根据ParentId递归【无限套娃】
    【软考设计师】【计算机系统】E01 计算机硬件组成与CPU
    CentOS7 利用remi yum源安装php8.1
    docker compose 管理应用服务的常用命令
    JavaScript使用正则表达式
    MARKDOWN 文档图片编码嵌入方案
    Postman 批量测试接口详细教程
    HarmonyOS UI 开发
  • 原文地址:https://blog.csdn.net/m0_47114547/article/details/127132283