2024.1.2 Redis 数据类型 Stream、Geospatial、HyperLogLog、Bitmaps、Bitfields 简介

目录

引言

Stream 类型

Geospatial 类型

HyperLogLog 类型

Bitmaps 类型

Bitfields 类型


引言

  • Redis 最关键(应用广泛、频繁使用)的五个数据类型
  1. String
  2. List
  3. Hash
  4. Set
  5. ZSet

  • 下文介绍的数据类型一般适合在特定的场景中使用!

Stream 类型

  • Stream 类型可理解为一个阻塞队列,可用记录和模拟实时的事件

什么是事件?

  • 有些操作,我们无法知道它啥时候会出现,所以只能等到这个事情出现了之后,再采取相应的动作来处理该事件

实例理解

  • JavaScript 中包含有 点击事件、键盘事件、窗口大小改变、位置改变事件 等
  • epoll 是 Linux 中特定的 I/O 多路复用机制,用于监视多个文件描述符的事件,每当 网卡 或 socket 上有可读可写的数据时,epoll 便会使用 事件回调机制 来通知应用程序

总结:

  • 官方文档的意思为 steam 类型可以用来模拟实现这种事件传播的机制

应用场景

  • stream 类型是 Redis 作为消息队列的重要支撑,属于 List 类型中 blpop 和 brpop 命令的升级版

Geospatial 类型

  • Geospatial 类型是指一组用于存储地理空间信息(地理位置)的数据结构和相关操作
  • 该类型主要用来存储坐标的(经纬度)

应用场景

  • 存储了一些坐标点后,便可让用户给定一个坐标,然后从刚才存储的坐标点中进行相应的查找
  • 比如 按照半径、矩形区域 等

  • 此处我们指定了一个坐标,并想要查找附近的美食此时地图上便会标识出符合要求的坐标位置

HyperLogLog 类型

  • HyperLogLog 类型不是 Redis 专有的类型,属于一种思想方法!
  • HyperLogLog 类型可用于 估算 集合中的不重复元素的个数

应用场景

  • Set 类型存在一个应用场景,即统计服务器的 UV (用户的访问次数)

明确:

  • 使用 Set 类型固然可以统计 UV,但是当 UV 的数据量非常大时,使用 Set 类型便会消耗很多内存空间

实例理解

  • 使用 Set 类型存储 userId,且单个 userId 按 8 字节算
  • 1亿 UV ——> 8 亿字节 ——> 0.8G ——> 800MB
  • 使用 Set 类型存储一亿个 userId 便需要消耗 800MB 的内存空间
  • 如果使用 HyperLogLog 类型,则最多消耗 12KB 的内存空间,便可实现上述效果!

重点理解:

  • 之所以 Set 类型要消耗这么大的空间,是因为 Set 类型需要存储每个元素
  • 而 HyperLogLog 类型却无需存储元素的内容,也能判断当前元素是否为重复元素
  • 因为 HyperLogLog 类型会提取新增元素的特征,并利用该特征来判断后续新增的元素是否为重复元素!

通俗理解:

  • HyperLogLog 类型适合用来计数,即记录出当前集合有多少个不同元素,但无法告诉你这些元素的内容是什么

注意:

  •  HyperLogLog 类型并不具有 100% 的精确性,即存在一定的误差
  • 官方文档描述误差大概为 0.81%

Bitmaps 类型

  • Bitmaps 类型使用 bit 位来表示整数

  • 位图(bitmaps)本质上还是一个集合,属于 Set 类型针对整数的特化版本
  • 其目的也还是为了节省空间,且也因为计算机进行位运算一般都是比较高效的

问题:

  • 相比于使用 Bitmap 类型,使用 HyperLogLog 类型更节省空间呀?

明确:

  • HyperLogLog 类型即可以存储数字,也可以存储字符串,但是 不存储元素内容,仅有计数效果
  • 因为 Hyperloglog 类型在存储元素的时候,提取特征的过程 是不可逆的!
  • 而 Bitmap 类型是实实在在存储了元素,即 可以通过遍历精确知道哪些元素已经存储

总结:

  • 通常我们首选还是使用 Set 类型,因为 Set 类型更加通用!
  • 如果存在这种极端的特定场景,再进而考虑使用 Bitmap 类型、Hyperloglog 类型

Bitfields 类型

  • Redis 的位域(bitfields)允许您设置、递增和获取任意位长度的整数值
  • 位域(bitfields)相较于之前的 String 、Hash 类型来说,其目的也是为了节省空间!

辅助理解:

  • C 语言中的位域 是一种结构体成员的特殊用法,允许你在内存中以位为单位对数据进行紧凑的存储

  • 位域 本质上是让我们进行精确位操作的一种方法

重点理解:

  • Bitfields 类型与 C 语言中的位域非常相似
  • Bitfields 类型可以理解成一串二进制序列(字节数组)
  • 程序员可以将这个字节数组中的某几个位赋予特定的含义,并且可以针对这某几个位进行 读取、修改、算数运算等相关操作

实例理解

  • 此处我们需要针对页游初始化新玩家的 金币数
  • 因此我们可以给每个玩家均分配一个位域,以此来表示每个玩家的 金币数
  • 此处假设每个新玩家初始状态均有 1000 金币
> BITFIELD player:1:stats SET u32 #0 1000
1) (integer) 0
  • 使用 BITFIELD 命令来进行操作
  • "player:1:stats" 为 key 值 
  • "SET" 属于 BITFIELD 命令下的一个子命令
  • "u32" ——> unsigned 32 ——> 无符号操作 32 个 bit 位
  • "#0" 相当于一个标签,此处表示 金币数
  • "1000" 设置的初始值 1000 金币

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis命令---Hash(哈希)篇 (超全)

目录 1.Redis Hmset 命令 - 同时将多个 field-value (域-值)对设置到哈希表 key 中。简介语法可用版本: > 2.0.0返回值: 如果命令执行成功,返回 OK 。 示例 2.Redis Hmget 命令 - 获取所有给定字段的值简介语法可用版本: > 2.0.0返回值: 一个包含多个给定字段…

LangChain与昇腾

LangChain这个词今年已经听烂了,今天基于昇腾的角度总结一下: Why LangChain ? 场景:构建一个LLM应用 在构建一个新项目时,可能会遇到许多API接口、数据格式和工具。要去研究每一个工具、接口很麻烦。 假设要构建一…

k8s二进制部署2

部署 Worker Node 组件 //在所有 node 节点上操作 #创建kubernetes工作目录 mkdir -p /opt/kubernetes/{bin,cfg,ssl,logs} #上传 node.zip 到 /opt 目录中,解压 node.zip 压缩包,获得kubelet.sh、proxy.sh cd /opt/ unzip node.zip chmod x kubelet.…

3分钟了解syscall系统调用|详细易懂的流程

文章目录 syscall1.简介2.详细解释3.具体举例4.比喻解释5.作用6.优点7.总结 syscall和int 0x80有什么不同?1. 上下文切换效率2. 指令执行流程3. 兼容性总结 syscall 具体流程1. 用户空间准备2. 执行syscall指令3. 切换到内核态4. 内核模式下执行系统调用5. 返回用户…

Unity3D UGUI图集打包与动态使用(TexturePacker)

制作图集的好处: 众所周知CPU是用来处理游戏的逻辑运算的,而GPU是用来处理游戏中图像的。在GPU中,我们要绘制一个图像需要提交图片(纹理)到显存,然后再进行绘制(在这个过程中会产生一次DrawCall…

vue3 + TS + vite 搭建中后台管理系统(完整项目)

vue3 TS vite 搭建中后台管理系统(完整项目) 前言1、搭建步骤及方法2、集成多种插件功能,实现中后台按需使用3、新手学TS如何快速进入状态、定义TS类型4、layout搭建四款常见风格6、大屏搭建效果5、vue3Ts运营管理系统总结: 前言…

three.js相机按照指定路线在建筑模型中漫游(支持开始,暂停)

three.js相机按照指定路线在模型中漫游(支持开始,暂停) 关键点 相机运动曲线 // 相机路线 const points [new THREE.Vector3(0, 40, 300),new THREE.Vector3(50, 40, 300),new THREE.Vector3(50, 40, 50),new THREE.Vector3(150, 40, 50),…

详细解读QLC SSD无效编程问题-2

作者通过SimpleSSD仿真模型,采用SLCQLC混合模式来开展进一步的验证工作。评估过程中,当写入请求到达固态硬盘时,首先会被写入缓存(DRAM),然后才被回写到NAND。文中引入了一个名叫做LRU(Least Recently Used…

【Unity中的A星寻路】Navigation导航寻路系统四大页签详解

👨‍💻个人主页:元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏:Uni…

几种读nii图像方法的轴序比较

读 .nii / .nii.gz 图像并转成 numpy 可用 medpy.io、nibabel、itk、SimpleITK 几种方法,然而几种方法读出来的轴序有出入,本篇比较此几种方法。 Datum 所用数据来自 verse,经 iTomxy/data/verse/preprocess.py 预处理,朝向和轴…

【观察】Aginode安捷诺:坚守“长期主义”,服务中国数字经济

毫无疑问,随着整个社会加速数字化转型,尤其是5G、人工智能、大数据等技术兴起,以及智慧医疗、智慧金融、智能制造等应用加速落地,算力网络在经济社会发展中扮演了愈来愈重要的角色,成为支撑数字经济蓬勃发展的“新引擎…

根本记不住MySQL进阶查询语句

1 MySQL进阶查询 1.1 MySQL进阶查询的语句 全文以数据库location和Store_Info为实例 ---- SELECT ----显示表格中一个或数个字段的所有数据记录 语法:SELECT "字段" FROM "表名"; select 列名 from 表名 ; ---- DISTINCT ----不显示重复的数…

高清网络视频监控平台的应用-城市大交通系统视联网

目 录 一、应用需求 二、系统架构设计 三、功能介绍 1.实时视频监控 2.云台控制 3.语音功能 4. 录像管理与回放 5.告警联动 6.多种显示终端呈现 (1)CS客户端 (2)web客户端 (3&#xf…

seo分享:慎重使用蜘蛛池

其实要提高搜索引擎蜘蛛的来访次数,唯一的方法还是要通过网站本身的内容更新。频繁更新有质量的内容,才能够提高蜘蛛的来访次数。如果本身内容更新不多,外部引流的蜘蛛过多,最终发现没什么内容索引,蜘蛛来访的次数也会…

【竞技宝】DOTA2:tundra宣布解散旗下阵容 whitemon留队

北京时间2024年1月4日,在DOTA2ESL吉隆坡站的比赛结束后,最近将要迎来的是BB Dacha别墅杯的预选赛,目前随着AR官宣新赛季阵容,国内一线队伍都已经全部公布了大名单。而国外还有一些队伍仍在进行人员调整,其中就包括前TI…

Strict MIME type checking is enforced for module scripts per HTML spec.

目录 前言错误信息如下:前言 最近使用docker打包Nginx和vue 为镜像文件,启动镜像时报错 错误信息如下: index89886.js:1 Failed to load module script: Expected a JavaScript module script but the server responded with a MIME type of "text/html". Stri…

MySQL之、CRUD、函数及union查询(实施必会)

文章目录 前言一、CRUD1.1SELECT(查询)1.2INSERT(新增)1.3UPDATE(修改)1.4DELETE(删除) 二、函数2.1常见函数2.1.1字符函数2.1.2数字函数2.1.3日期函数 2.2流程控制函数(重点)2.3聚合函数 三、union与union all思维导图: 前言 本篇博主给大家带来MySQL之、CRUD、常…

搜维尔科技:ART光学跟踪系统在工业VR/AR领域的应用

ART公司成立于1999年,拥有38万员工遍布全球,ART一直致力于红外线光学跟踪系统的研发与生产,并将先进的科技应用于产品研发,产品制造,市场营销,产品销售以及优秀的客户支持。主要向客户提供高端的虚拟现实跟…

MySQL Enterprise版本各系统安装包下载

一、官方下载地址 oracle下载地址 https://edelivery.oracle.com/osdc/faces/SoftwareDelivery 使用oracle账号登录进去 Category选择Download Package(下载安装包),搜索栏输入mysql Enterprise关键字点search进行搜索。选项结果第一个MySQL Enterprise Edition&a…

JAVA的引用与C++的指针有什么区别

JAVA的引用与C的指针有什么区别 1. Java值类型与引用类型1.1 变量初始化1.2 变量赋值1.3 函数传参 2. Java数据存储方式2.1 Java局部变量&&Java方法参数2.2 Java数组类型引用和对象2.3 String类型数据 3. Java引用类型3.1 强引用3.2 软引用3.3 弱引用3.4 虚引用 4. JAV…