码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Redis:19-Redis6新特性


    文章目录

      • 一、ACL
        • 1、ACL简介
        • 2、ACL命令
      • 二、IO多线程
        • 1、IO多线程简介
        • 2、原理架构
      • 三、工具支持 Cluster
      • 四、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许可。

  • 相关阅读:
    老实说,分支预测,是高手过招的杀手锏,但是对写业务代码没啥帮助。
    使用三丰云免费主机搭建zerotier网络
    在Winform程序中动态绘制系统名称,代替图片硬编码名称
    前端例程20221024:流光效果按钮
    《机器学习by周志华》学习笔记-线性模型-02
    搭建mysql的主从关系
    更改当前动作路径为文件坐在地址路径,应对./这种情况,有利于项目移动
    python每日学5:python工程(大型项目)的组织架构:包、模块、类、方法
    NCCL后端
    多商户商城系统源码,同类产品选择多,买东西更划算
  • 原文地址:https://blog.csdn.net/m0_47114547/article/details/127132283
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号