Redis6新功能

Redis6新功能

ACL

简介:

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

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

    1. 接入权限:用户名和密码
    2. 可以执行的命令
    3. 可以操作的KEY
  3. 参考官网:https://redis.io/topics/acl

命令:

  1. 使用acl list命令展现用户权限列表
  • 数据说明
    在这里插入图片描述
  1. 使用acl cat命令

在这里插入图片描述

  • 查看添加权限指令类别
  • 加参数类型名可以查看类型下具体命令

在这里插入图片描述

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

在这里插入图片描述

  1. 使用aclsetuser命令创建和编辑用户ACL
  2. ACL规则
  • 下面是有效ACL规则的列表。某些规则只是用于激活或删除标志,或对用户ACL执行给定更改的单个单词。其他规则是字符前缀,它们与命令或类别名称、键模式等连接在一起。
    在这里插入图片描述

  • 通过命令创建新用户默认权限

    • acl setuser user1

在这里插入图片描述

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

  • 设置有用户名、密码、ACL权限、并启用的用户

    • acl setuser user2 on >password ~cached:* +get

在这里插入图片描述

  • 切换用户,验证权限

在这里插入图片描述

IO多线程

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

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

原理架构

  1. Redis6加入多线程,但跟Memcached这种从IO处理到数据访问多线程的实现模式有些差异。
  2. Redis的多线程部分只是用来处理网络数据的读写和协议解析,执行命令仍然是单线程。
  3. 这么设计是不想因为多线程而变得复杂,需要去控制 keyluatransactionLPUSH/LPOP 等等的并发问题。
  4. 整体的设计大体如下:

在这里插入图片描述

  1. 另外,多线程IO默认也是不开启的,需要再配置文件中配置
io-threads-do-reads  yes 
io-threads 4

工具支持 Cluster

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

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值