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

相关文章

SpringCloud Stream 快速入门实例教程

《SpringCloudStream快速入门实例教程》本文介绍了SpringCloudStream(SCS)组件在分布式系统中的作用,以及如何集成到SpringBoot项目中,通过SCS,可... 目录1.SCS 组件的出现的背景和作用2.SCS 集成srping Boot项目3.Yml 配置4.Sprin

Redis 命令详解与实战案例

《Redis命令详解与实战案例》本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统... 目录Redis 命令详解与实战案例一、Redis 基础介绍二、Redis 核心数据结构与命令1. 字符

SpringBoot18 redis的配置方法

《SpringBoot18redis的配置方法》本文介绍在SpringBoot项目中集成和使用Redis的方法,包括添加依赖、配置文件、自定义序列化方式、使用方式、实际使用示例、常见操作总结以及注意... 目录一、Spring Boot 中使用 Redis1. 添加依赖2. 配置文件3. Redis 配置类

Redis中群集三种模式的实现

《Redis中群集三种模式的实现》Redis群集有三种模式,分别是主从同步/复制、哨兵模式、Cluster,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1. Redis三种模式概述2、Redis 主从复制2.1 主从复制的作用2.2 主从复制流程2

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

Docker + Redis 部署集群的实现步骤

《Docker+Redis部署集群的实现步骤》本文详细介绍了在三台服务器上部署高可用Redis集群的完整流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、环境准备1. 服务器规划(3 台服务器)2. 防火墙配置(三台服务器均执行)3. 安装 docke

Redis中删除策略的几种实现方式

《Redis中删除策略的几种实现方式》本文详细介绍了Redis的过期键删除策略和内存淘汰策略,过期键删除策略包括定时删除、惰性删除和定期删除,具有一定的参考价值,感兴趣的可以了解一下... 目录前言一、设计背景:为什么需要删除策略?二、第一类:过期键的 3 种核心删除策略1. 定时删除(Timed Dele

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash