Redis篇 - 3. 发布订阅、geo、bitmap、hyperloglog

1、发布订阅
  1. 简介

    1. 发布订阅类似于广播功能。redis发布订阅包括 发布者、订阅者、Channel
  2. 命令
命令作用时间复杂度
subscribe channel订阅一个频道O(n)
unsubscribe channel …退订一个/多个频道O(n)
publish channel msg将信息发送到指定的频道O(n+m),n 是频道 channel 的订阅者数量, M 是使用模式订阅(subscribed patterns)的客户端的数量
pubsub CHANNELS查看订阅与发布系统状态(多种子模式)O(n)
psubscribe订阅多个频道O(n)
unsubscribe退订多个频道O(n)
2、geo
  1. 简介

    1. geo是地理空间位置。redis支持将geo信息存储到有序集合中,再通过geohash算法进行填充
  2. 命令
命令作用
geoadd key latitude longitude member添加成员位置(纬度、经度、名称)到key中
geopos key member …获取成员geo坐标
geodist key member1 member2计算成员位置间距离
georadius基于经纬度坐标范围查询
georadiusbymember基于成员位置范围查询
geohash计算经纬度hash
3、bitmap
  1. 简介

    1. bitmap是一串连续的2进制数字(0或1),每一位所在的位置为偏移(offset),在bitmap上可执行AND, OR, XOR以及其它位操作
  2. 命令
命令作用时间复杂度
setbit key offset val给指定key的值的第offset赋值valO(1)
getbit key offset获取指定key的第offset位O(1)
bitcount key start end返回指定key中[start,end]中为1的数量O(n)
bitop operation destkey key对不同的二进制存储数据进行位运算(AND、OR、NOT、XOR)O(n)
4、hyperloglog
  1. 简介

    1. hyperloglog可用极小空间完成独立数统计
  2. 命令
命令作用
pfadd key element …将所有元素添加到key中
pfcount key统计key的估算值(不精确)
pgmerge new_key key1 key2 …合并key至新key

PS: 更多文章请关注微信公众号:浮话

    原文作者:浮话
    原文地址: https://segmentfault.com/a/1190000019321768
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞