• 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: 更多文章请关注微信公众号:浮话

  • 相关阅读:
    为动态添加的元素,绑定click事件
    Struts报错NoSuchMethodException的解决方法
    Struts报错ObjectNotFoundException的解决方法
    HTML通知、新闻等文字列表的无缝滚动效果
    HTML通过使用JS动态显示table内容
    CentOS下整合Apache与Tomcat的一种方法
    Centos下Apache整合Tomcat访问报Forbidden 403 错误的解决方法
    从Google趋势来看五大联赛在世界范围内的影响力
    Java实现多线程的三种方法
    DataGrid中插入Combobox选择框
  • 原文地址:https://www.cnblogs.com/jie-hu/p/10940649.html
Copyright © 2020-2023  润新知