redis 特殊功能 - 文章教程

redis 特殊功能

发布于 2021-08-06 字数 2712 浏览 799 评论 0

一、慢查询

生命周期

redis 特殊功能

两点说明:

(1)、慢查询发生在第三阶段
(2)、客户端超时不一定慢查询,但慢查询是客户端超时的一个因素。

两个配置

(1)、slowlog-max-len
 先进先出的队列、固定长度、保存在内存内
(2)、slowlog-log-slower-than
满查询阀值(单位:微妙)、slowlog-log-slower-than=0记录所有命令、slowlog-log-slower-than<0不记录所有命令

默认值:
config get slowlog-max-len = 128
config get slowlog-log-slower-than = 10000
修改配置文件重启
动态配置:
config set slowlog-max-len 1000
config set slowlog-log-slower-than 1000

三个命令

slowlog get [n]    //获取慢查询队列
slowlog len        //获取满查询队列长度
slowlog reset      //清空慢查询队列

二、pipeline

将多个 redis 命令打包 1 次 pipeline 命令 = 1次网络时间 + n 次命令时间

(1)、注意每次pipeline携带数据量
(2)、pipeline每次只能作用在一个redis节点上

三、发布订阅

1、角色

发布者(publisher)
订阅者(subscriber)
通道(channel)

2、模型

redis 特殊功能

注意:新订阅者无法收到历史消息。

3、API

publish:发布->publish channel message(publish sohu:tv "hello world")返回订阅者个数
subscribe:订阅->subscribe [channel]#一个或多个(subscribe sohu:tv)
unsubscribe:取消订阅->unsubscribe [channel]#一个或多个(unsubscribe sohu:tv)

psubscribe [pattern...]#订阅模式
punsubscribe [pattern...]#退订指定的模式
pubsub channels#列出至少有一个订阅者的频道
pubsub numsub [channel...]#列出给定频道的订阅者数量

4、发布订阅与消息队列

发布订阅:发布者发布之后订阅者都可以收到。 消息队列:发布者发布以后订阅者只有一个可以收到(抢占)

四、bitmap

位图:可以直接次操作位(一个字节 8 位)

五、hyperloglog(统计独立用户)

基于 HypeLogLog 算法:极小空间完成独立数量统计

本质还是字符串

三个命令

1、pfadd key element [element...]:向hyperloglog添加元素
2、pfcount key [key...]:计算hyperloglog的独立总数
3、pfmerge destkey sourcekey [sourcekey...]:合并多个hyperloglog

内存消耗:内存消耗较小

使用经验:

  1. 能否容忍错误?(错误率:0.81)。
  2. 是否需要单条数据(没有)

如果你对这篇文章有疑问,欢迎到本站 社区 发帖提问或使用手Q扫描下方二维码加群参与讨论,获取更多帮助。

扫码加入群聊

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

目前还没有任何评论,快来抢沙发吧!

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

2512 文章
30 评论
82706 人气
更多

推荐作者

瑾兮

文章 11 评论 2

carlo_sn

文章 0 评论 0

15867725375

文章 0 评论 0

a3576419

文章 0 评论 0

wendy

文章 0 评论 0