Redis 数据类型及其常用命令二(bitmap、geo、hyperloglog、bitfield、stream)

本文主要是介绍Redis 数据类型及其常用命令二(bitmap、geo、hyperloglog、bitfield、stream),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        上文中我们介绍了Redis常使用的5中数据类型,对于一些特殊的场景,我们需要使用特殊的数据类型,本文将详细介绍5种特殊的数据类型。

1、bitmap 类型

        用String类型作为底层数据结构实现的一种统计二值状态的数据类型。位图本质是数组,它是基于String数据类型的按位的操作。该数组由多个二进制位组成,每个二进制位都对应一个偏移量( 我们称之为一个索引)。Bitmap支持的最大位数是2^32位,它可以极大的节约存储空间,使用512 M内存就可以存储多达42.9亿的字节信息(2^32 = 4294967296)。

# 1、设置值
setbit key offset value # value 只能是 0 或 1
# 2、获取值
getbit key offset
# 3、统计占用bit数,不是字符串长度,超过8位后自己按照8位一组一byte再扩容
strlen key
# 4、统计全部键中1的个数
bitcount key
# 5、位运算(and、or ...)
bitop AND|OR|XOR|NOT destkey key [key ...]
2、HyperLoglog 类型

        在Redis里面,每个HyperLoglog键只需花费12KB内存,就可以计算2^64个不同元素的基数。该数据类型可以去除重复统计的基数估算方法(一种数据集,去除重复元素后真实个数)。

# 1、添加元素
pfadd key v1 v2 v3 ...
# 2、返回HyperLoglog的基数估算值
pfcount key1 key2 ...
# 3、将多个HyperLoglog合并成一个
pfmerge destkey key1 key2 key3 ...
3、 geo 地理空间

        地球上的地理位置是使用二维的经纬度表示,经度范围 (-180, 180],纬度范围 (-90, 90],只要我们确定一个点的经纬度就可以名取得他在地球的位置

# 1、存储指定的地理空间
GEOADD key 经度 纬度 地名 经度1 纬度1 地名1 ...
# GEOADD city 116.403963 39.915119 "天安门" 116.403414 39.924091 "故宫" 116.024067 40.362639 "长城"
# 2、返回指定的地名的经纬度
GEOPOS key 地名1 地名2 ...
# 3、返回地理位置的hash值
geohash key 地名1 地名2 ...
# 4、返回两个位置之间的距离
geodist key 地名1 地名2 [M|KM|FT|MI]  # 米|千米|英尺|英里
# 5、以给定的经纬度为中心, 距离不超过给定最大距离的所有位置元素
georadius key 经度 纬度 距离 km withdist withcoord count 10 withhash desc
# WITHDIST: 在返回位置元素的同时, 将位置元素与中心之间的距离也一并返回。 距离的单位和用户给定的范围单位保持一致。
# WITHCOORD: 将位置元素的经度和维度也一并返回。
# WITHHASH: 以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大
# COUNT 限定返回的记录数。
4、 bitfield 类型

        这个里类型不常用,简单了解即可。bitfield是将一个Redis字符串看作一个二进制数组,并能对变长位宽和任意没有字节对齐的指定整型域进行寻址和修改。

BITFIELD key [GET type offset] [SET type offset value] [INCRBY type offset increment] [OVERFLOW WRAP|SAT|FAIL]
5、Steam 类型

        Stream 类型是Redis5.0版本新增的数据结构,实现消息队列,支持消息持久化、支持自动生成全局唯一ID,支持ack确认消息模式,支持消费者组模式等,就是Redis实现MQ。一般消息队列使用其他中间件实现,如果是小型项目可以考虑Stream数据类型,具体使用将在后续有使用场景时介绍。

6、总结

        本文介绍了Redis 另外五种数据结构:bitmap、geo、hyperloglog、bitfield、stream,从使用命令入手,熟悉每个数据结构的使用场景和使用方式,帮助大家更加深入熟悉Redis。

·        本人是一个从小白自学计算机技术,对运维、后端、各种中间件技术、大数据等有一定的学习心得,想获取自学总结资料(pdf版本)或者希望共同学习,关注微信公众号:it自学社团。后台回复相应技术名称/技术点即可获得。(本人学习宗旨:学会了就要免费分享)

        

这篇关于Redis 数据类型及其常用命令二(bitmap、geo、hyperloglog、bitfield、stream)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/726109

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject