zoukankan      html  css  js  c++  java
  • redis 发布订阅、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赋值val O(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: 更多文章请关注微信公众号:浮话

  • 相关阅读:
    css文字选中效果
    使用HTML5来实现本地文件读取和写入
    web响应式图片的5种实现
    前端日志上报的新姿势“Beacon”
    lock文件_我们为什么需要 lock 文件
    本地电脑和远程电脑无法复制粘贴
    device supports x86 but apk only supports armeabi-v7a问题解决
    Android Studio中 安卓模拟器 联网
    Android Studio 配置Gradle
    Android连载1-自定义UI控件
  • 原文地址:https://www.cnblogs.com/jie-hu/p/10940649.html
Copyright © 2011-2022 走看看