您当前的位置:首页 > 计算机 > 软件应用 > 数据库 > Redis

redis 特殊功能

时间:12-14来源:作者:点击数:
城东书院 www.cdsy.xyz

一、慢查询

生命周期

两点说明:

(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、模型

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

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. 是否需要单条数据(没有)
城东书院 www.cdsy.xyz
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐