【Redis】Redis 高级数据类型Bitmaps、HyperLogLog、GEO

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 【Redis】Redis 高级数据类型Bitmaps、HyperLogLog、GEO

一、Bitmaps

image.png

对于bitmap,我们取值的时候,需要知道bit的位置,改值的时候,需要知道位置和修改结果。取值和修改的操作变得复杂了一些,但是节省了存储空间,属于时间换空间其实redis并没有提供bitmap这种数据类型,只是提供了对string类型操作bit的接口

1. Bitmaps基本操作

设置指定key对应偏移量上的bit值,value只能是1或0


setbit key offset value

获取指定key对应偏移量上的bit值


getbit key offset

image.png

如果我们在一个比较大的位设置的时候,这是比较耗时的,同时也耗费空间

image.png

所以当我们设置的位都很大的时候,我们统一减去一个offset后,再进行setbit

2. Bitmaps扩展操作

电影网站业务场景

  • 统计每天某一部电影是否被点播
  • 统计每天有多少部电影被点播
  • 统计每周/月/年有多少部电影被点播
  • 统计年度哪部电影没有被点播

image.png

对指定key按位进行交、并、非、异或操作,并将结果保存到destKey中


bitop op dstKey key1 [key2…]  # op是位操作符,and or not xor,key1、key2是运算数,dstKey用于存放运算结果

统计指定key中1的数量

bitcount key [start end]

image.png

分别查看8月8日和8月9日被看过电影的数量(哪些bit为1)

image.png

统计8号和9号有哪些电影被看了(8号和9号被看得bit置为1,用逻辑或即可得到被看的所有电影)

image.png

二、HyperLogLog

统计独立UV的方法有如下几种:

原始方案 set:存储每个用户的id(字符串)

改进方案Bitmaps:存储每个用户状态(bit)

全新的基数统计方案:Hyperloglog。应用场景单一,只做基数统计

基数就是数据集去重后元素的个数,HyoerLogLog运用了LogLog的算法,做基数统计

image.png

HyperLogLog类型的基本操作

  • 添加数据


pfadd key element [element …]
  • 统计数据


pfcount key [key …]
  • 合并数据


pfmerge destkey sourcekey [sourcekey …]

image.png

相关注意事项

  • HyperLogLog用于基数统计,不是集合,不保存数据,只记录数量而不是具体数据
  • 核心是计数估算算法,最终数值存在一定误差,误差范围大概是0.81%
  • 消耗空间极小,每个hyperloglog key占用了12k的内存用于标记基数
  • pfadd命令不是一次性使用12k内存,会随着基数的增加内存逐渐增大,12k是上限
  • pfmerge命令合并后占用的内存空间为12k(涉及到分桶,默认用最大的空间12K),无论合并之前数据量多少

三、GEO

image.png

GEO类型的基本操作

  • 添加坐标点


# key:容器名   
# longitude latitude:横纵坐标
# member:地点名称
geoadd key longitude latitude member [longitude latitude member]
  • 获取坐标点


geopos key member[member …]
  • 计算坐标点距离


geodist key member1 member2 [unit]

image.png

  • 根据坐标求范围内的数据


georadius key longitude latitude radius m|km|ft|mi [withcoord] [withdist] [withhash] [count count]
  • 根据点求范围内的数据


georadiusbymember key member radius m|km|ft|mi [withcoord] [withdist] [withhash] [count count]
  • 获取指定点对应的坐标的hash值


geohash key member [member ...]

image.png

image.png

image.png

image.png



相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1天前
|
NoSQL 安全 Java
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
这篇文章深入探讨了Redis中的String数据类型,包括键操作的命令、String类型的命令使用,以及String在Redis中的内部数据结构实现。
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
|
1天前
|
存储 NoSQL 算法
Redis6入门到实战------ 三、常用五大数据类型(列表(List)、集合(Set)、哈希(Hash)、Zset(sorted set))
这是关于Redis 6入门到实战的文章,具体内容涉及Redis的五大数据类型:列表(List)、集合(Set)、哈希(Hash)、有序集合(Zset(sorted set))。文章详细介绍了这些数据类型的特点、常用命令以及它们背后的数据结构。如果您有任何关于Redis的具体问题或需要进一步的帮助,请随时告诉我。
|
3天前
|
存储 缓存 NoSQL
Redis深度解析:部署模式、数据类型、存储模型与实战问题解决
Redis深度解析:部署模式、数据类型、存储模型与实战问题解决
|
5天前
|
NoSQL Java Redis
Redis字符串数据类型之INCR命令,通常用于统计网站访问量,文章访问量,实现分布式锁
这篇文章详细解释了Redis的INCR命令,它用于将键的值增加1,通常用于统计网站访问量、文章访问量,以及实现分布式锁,同时提供了Java代码示例和分布式锁的实现思路。
13 0
|
4天前
|
NoSQL 数据可视化 Redis
Mac安装Redis
Mac安装Redis
15 3
|
5天前
|
NoSQL Ubuntu 安全
在Ubuntu 18.04上安装和保护Redis的方法
在Ubuntu 18.04上安装和保护Redis的方法
14 0
|
1天前
|
NoSQL Redis 数据安全/隐私保护
Redis6入门到实战------ 二、Redis安装
这篇文章详细介绍了Redis 6的安装过程,包括下载、解压、编译、安装、配置以及启动Redis服务器的步骤。还涵盖了如何设置Redis以在后台运行,如何为Redis设置密码保护,以及如何配置Redis服务以实现开机自启动。
Redis6入门到实战------ 二、Redis安装
|
1天前
|
NoSQL 数据可视化 Linux
2022 年超详细步骤讲解 CentOS 7 安装Redis 。解决Redis Desktop Manager 图形化工具连接失败解决 ;connection failed处理。开机自启Redis
这篇文章提供了在CentOS 7上安装Redis的详细步骤,包括上传Redis安装包、解压安装、编译、安装、备份配置文件、修改配置以支持后台运行和设置密码、启动Redis服务、使用客户端连接Redis、关闭Redis服务、解决Redis Desktop Manager图形化工具连接失败的问题、设置Redis开机自启动,以及Redis服务的启动和停止命令。
2022 年超详细步骤讲解 CentOS 7 安装Redis 。解决Redis Desktop Manager 图形化工具连接失败解决 ;connection failed处理。开机自启Redis
|
5天前
|
存储 NoSQL Java
使用redis进行手机验证码的验证、每天只能发送三次验证码 (redis安装在虚拟机linux系统中)
该博客文章展示了如何在Linux虚拟机上使用Redis和Jedis客户端实现手机验证码的验证功能,包括验证码的生成、存储、验证以及限制每天发送次数的逻辑,并提供了测试结果截图。
使用redis进行手机验证码的验证、每天只能发送三次验证码 (redis安装在虚拟机linux系统中)
|
5天前
|
NoSQL Linux 网络安全
Linux系统安装Redis
该博客文章详细介绍了在Linux系统中安装Redis的步骤,包括下载、编译、配置、启动Redis服务以及使用客户端访问Redis数据库的过程。
Linux系统安装Redis