Redis 特殊数据类型
目录
1、redis地理空间(GEO)
2、redis基数统计(HyperLogLog)
3、redis位图(bitmap)
4、redis位域bitfield)
5、redis流(Stream)
1、redis地理空间(GEO)
Redis 的地理空间数据结构(GEO)可以用于存储地理位置信息,并支持附近位置搜索等功能。
| 命令 | 描述 |
|---|---|
| GEOHASH | 返回一个或多个位置元素的 Geohash 表示 |
| GEOPOS | 从key里返回所有给定位置元素的位置(经度和纬度) |
| GEODIST | 返回两个给定位置之间的距离 |
| GEORADIUS | 以给定的经纬度为中心, 找出某一半径内的元素 |
| GEOADD | 将指定的地理空间位置(纬度、经度、名称)添加到指定的key中 |
| GEORADIUSBYMEMBER | 找出位于指定范围内的元素,中心点是由给定的位置元素决定 |
应用场景
-
附近的人/店铺搜索:可以使用 GEO 数据结构来存储用户或商店的地理位置信息,然后通过 Redis 提供的命令进行附近的人或店铺搜索,例如查找附近的餐馆、商店或其他服务设施。
-
地理围栏监控:通过 GEO 数据结构记录移动物体的实时位置,并结合有序集合(Sorted Set)来实现地理围栏监控,比如在特定区域内的移动车辆或设备监控。
-
地理位置标注:将地理位置信息与其他业务数据关联,比如将特定位置的销售点、活动场所等信息与地理位置进行标注,以支持位置相关的业务查询和展示。
2、redis基数统计(HyperLogLog)
Redis 的基数统计(HyperLogLog)数据结构用于估算一个集合中不重复元素的个数,能够在占用较小内存的同时对大数量级的数据进行近似计数。
| PFADD | 添加元素到 HyperLogLog 中 | 示例: 说明:向名为 |
| PFCOUNT | 获取 HyperLogLog 中的近似基数 | 示例: 说明:返回值为近似的基数,即 HyperLogLog 中不重复元素的数 |
| PFMERGE | 合并多个 HyperLogLog | 示例: 说明:将多个 HyperLogLog 合并为一个新的 HyperLogLo |
应用场景
-
独立访客统计:可以使用 HyperLogLog 数据结构来进行网站或应用的独立访客数量统计,而不需要存储每个访客的详细信息,节省内存空间。
-
活跃用户统计:对于大型在线平台,可以使用 HyperLogLog 计数活跃用户数量,而无需维护每个用户的详细浏览记录。
-
广告点击量统计:在广告分析领域,HyperLogLog 可以用于估算独立用户的广告点击数量,而不必存储每次点击的详细信息。
3、redis位图(bitmap)
Redis中的位图(bitmap)是一种特殊的数据结构,它通常用于表示某种状态或者标记,每个比特位可以表示一个状态或者标记的存在与否。
| setbit | 设置位图中的某一位 | 示例: 说明:将user 1的在线状态设置为1(在线),偏移量为1001 |
| getbit | 获取位图中的某一位的值 | 示例: 说明:返回值为0或1,表示偏移量为1001的位的 |
| strlen | 统计字节数占用多少 | 示例:user:1:online |
| bitcount | 统计位图中值为1的位数 | 示例: 说明:可选参数 |
| bitop | 对多个位图进行逻辑运算 | 示例: 说明:将user 1和user 2的在线状态做与操作,存储到 |
应用场景
- 用户在线状态:可以使用位图来表示用户的在线状态,每个比特位代表一个用户,值为1表示在线,值为0表示离线。
- 统计用户活跃度:使用位图记录用户每天的活跃情况,以便后续进行活跃度分析和统计。
- 标记用户行为:可以用位图来标记用户的某些行为,比如签到、阅读等,每个比特位代表一个行为,值为1表示有该行为,值为0表示没有。
4、redis位域bitfield)
Redis 的位域(Bitfield)数据结构提供了位级别的操作,可以方便地对二进制位进行读取和修改,适用于一些需要对大量位操作的场景。
| BITFIELD | 设置位域中的指定位 | 示例: 说明:在名为 |
| GETBIT | 获取位域中的指定位 | 示例: 返回值为指定偏移处的位的值。 |
| BITOP | 对位域进行位运算 | 示例: 说明:将多个位域进行指定的位运算(AND/OR/XOR/NOT)后存储到目标位域。 |
应用场景
-
权限管理:位域可以用于表示用户或角色的权限,每一位代表一种权限状态,通过位运算可以方便地进行权限的赋予与撤销。
-
实时状态标记:对于实时状态的标记,比如设备状态、用户在线状态等,位域可以高效地存储并更新这些状态信息。
-
布隆过滤器:布隆过滤器是一种空间效率很高的概率型数据结构,常用于快速判断一个元素是否存在。在 Redis 中,可以利用位域来实现布隆过滤器。
5、redis流(Stream)
Redis 的流(Stream)数据结构是一个有序、可持久化的消息队列,可以用于实现消息发布订阅系统、事件日志、通知系统等功能。
| XADD | 发布消息到流 | 示例: 说明:向名为 |
| XREAD | 消费者消费消息 | 示例: 说明:从名为 |
| XACK | 消费者确认消息 | 示例: 说明:消费者组 |
| XGROUP | 创建消费者组 | 示例: 说明:创建名为 |
应用场景
-
消息队列:流可以作为高性能的消息队列使用,允许按照发布的顺序进行消费,支持多个消费者并行处理消息。这种模式非常适合需要处理大量实时消息的业务场景。
-
事件日志:流可以用于记录系统的事件日志,包括用户操作、系统状态变化等,以便后续进行分析和故障排查。
-
通知系统:流可以用于构建实时的通知系统,例如实时推送用户的消息、提醒和通知。
相关文章:
Redis 特殊数据类型
目录 1、redis地理空间(GEO) 2、redis基数统计(HyperLogLog) 3、redis位图(bitmap) 4、redis位域bitfield) 5、redis流(Stream) 1、redis地理空间(GEO) Redis 的地理空间数据结构(GEO)可以用于存储地理位置信息,并支持附近位置搜索等功能…...
【Windows网络编程】二.TCP套接字编程与主机上线实验
API: socket: 套接字函数创建绑定到特定传输服务提供程序的套接字。 函数原型:SOCKET WSAAPI socket([in] int af,[in] int type,[in] int protocol );参数: af:地址规范系列: AF_INET:IPv4&…...
Qt 事件循环
引出 UI程序之所叫UI程序,是因为需要与用户有交互,用户交互一般是通过鼠标键盘等的输入设备,那UI程序就需要有能随时响应用户交互的能力。 一个C程序的main函数大概是下面这样: int main() {...return 0; } 我们如何使程序能随…...
【趣味随笔】YOLO的“进化史”极简版(YOLO v1-->YOLOP)
📢:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨ 📢:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 📢:文章若有幸对你有帮助,可点赞 👍…...
Leetcode421. 数组中两个数的最大异或值
Every day a Leetcode 题目来源:421. 数组中两个数的最大异或值 解法1:贪心 位运算 初始化答案 ans 0。从最高位 high_bit 开始枚举 i,也就是 max(nums) 的二进制长度减一。设 newAns ans 2i,看能否从数组 nums 中选两个…...
SPRINGBOOT整合CXF发布WEB SERVICE和客户端调用(用户和密码验证)
主要分为客户端和服务端 服务端 pom配置 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.4.3</version><relativePath/> <!-- lookup parent fro…...
代码随想录训练营Day5:哈希数组
算是哈希的容器:数组(适合连续存放);set,map(适合无序存放)。所以数组操作就是hash[i];而set,map.insert(元素),map可以map[]是因为map存放了键值对可以索引查找。关于几个数组相加等…...
腾讯云3年轻量2核2G4M和2核4G5M服务器540元三年
腾讯云轻量应用服务器特价是有新用户限制的,所以阿腾云建议大家选择3年期轻量应用服务器,一劳永逸,免去续费困扰。腾讯云轻量应用服务器3年可以选择2核2G4M和2核4G5M带宽,3年轻量2核2G4M服务器540元,2核4G5M轻量应用服…...
程序员的护城河:职业发展的关键元素
目录 1. 技术深度与广度 2. 项目经验与实际操作 3. 沟通与团队协作 4. 持续学习与自我更新 5. 社区参与与开源贡献 6. 创新思维与解决问题的能力 7. 职业规划与自我管理 结语 在科技日新月异的今天,程序员的竞争已经不再仅仅依赖于技术水平,而是…...
基于SpringBoot+Vue的在线学习平台系统
基于SpringBootVue的在线学习平台系统的设计与实现~ 开发语言:Java数据库:MySQL技术:SpringBootMyBatisVue工具:IDEA/Ecilpse、Navicat、Maven 系统展示 主页 用户界面 登录界面 管理员界面 摘要 本文设计并实现了一套基于Spri…...
Kafka+redis分布式锁结合使用心得总结
#kafka部分 KafkaListener(topics "#{${vsmart_alert_detection_tms_send_message_topic}.split(,)}", groupId "${vsmart.alert.detection.consumer.group}") public void vsmartAlertDetectionTmsSendMessage(ConsumerRecord<?, ?> record, A…...
cmd打开idea
当我们用idea打开一个项目的时候,有时候这个项目目录是有的,但是用idea的open却找不到,有时候我要重新关闭窗口,再open好多次才有 于是我现在使用命令打开,先把idea安装路径的bin目录放在path里面 然后cd到项目路径&…...
javaScript爬虫程序抓取评论
由于评论区目前没有开放的API接口,所以我们不能直接通过编程获取到评论区的内容。但是,我们可以通过模拟浏览器的行为来实现这个功能。以下是一个使用Python的requests库和BeautifulSoup库来实现这个功能的基本思路: import requests from bs…...
RT-DETR 应用 CARAFE:特征内容感知重新组装
特征上采样是现代卷积神经网络架构中的关键操作,例如特征金字塔。其设计对于密集预测任务,如目标检测和语义/实例分割至关重要。在本研究中,我们提出了一种称为内容感知特征重组(CARAFE)的通用、轻量级且高效的操作符,以实现这一目标。CARAFE具有以下几个优点:(1)大的…...
Git Commit 之道:规范化 Commit Message 写作指南
1 commit message 规范 commit message格式都包括三部分:Header,Body和Footer <type>(<scope>): <subject><body><footer>Header是必需的,Body和Footer则可以省略 1.1 Header Type(必需…...
【机试题】LazyIterator迭代器懒加载问题
将下面这个未完成的Java工具类补充完成,实现懒加载的功能,该类需要实现Iterable接口,能够遍历所有数据。具体要求如下: 工具类提供了一个ValueLoader接口,用于获取数据,其中ValueLoader的接口定义为&#x…...
【面试经典150 | 位运算】位1的个数
文章目录 写在前面Tag题目来源题目解读解题思路方法一:循环检查二进制位方法二:位运算优化方法三:__builtin_popcount() 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…...
vue中数据代理和事件处理
数据代理 直接在对象下可直接修改属性的值,而Object提供defineProperty()对属性进行控制 <script>let perosn {name: 小蜜,sex: 男,//age: 19 }Object.defineProperty(perosn,age,{value: 19//enumerable: true ,添加enumerable将默认值改为true,…...
Unity之NetCode多人网络游戏联机对战教程(8)--玩家位置同步
文章目录 前言添加相机玩家添加对应组件服务端权威(server authoritative)客户端权威(client authoritative)服务端同步位置阅读与理解PlayerTransformSync.csNetworkVariableUploadTransformSyncTransform 后话 前言 承接上篇&a…...
spring boot 中@Value读取中文配置时乱码
1.spring boot 读取application.properties 该文件是iso8859编码 如果是直接写中文 读取时会乱码 显示成?? 必须得转ascii码才能正常显示 其他方法测试也不行 Value("${apig.order.tiaokong.qianzi}") private String apigOrderTiaokongQianzi;...
Phi-3-vision-128k-instruct代码生成辅助:将UI设计稿截图转换为前端代码描述
Phi-3-vision-128k-instruct代码生成辅助:将UI设计稿截图转换为前端代码描述 1. 引言:设计稿转代码的痛点与解决方案 每次拿到设计师发来的Figma或Sketch文件,前端开发者都要面对一个耗时的工作:把视觉设计转化为可运行的代码。…...
革命性知识图谱项目Knowledge-Graph:一站式掌握深度学习与NLP核心技术
革命性知识图谱项目Knowledge-Graph:一站式掌握深度学习与NLP核心技术 【免费下载链接】NLP-Knowledge-Graph 项目地址: https://gitcode.com/gh_mirrors/kn/Knowledge-Graph Knowledge-Graph是一个全面的开源项目,专注于知识图谱与自然语言处理…...
Qwen3.5-9B惊艳效果:上传Excel截图→识别表格→生成SQL查询语句演示
Qwen3.5-9B惊艳效果:上传Excel截图→识别表格→生成SQL查询语句演示 1. 开篇:认识Qwen3.5-9B的强大能力 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,它在多个领域展现出惊人的能力。这个模型最吸引人的特点是它不仅能处理文字ÿ…...
Qwen3-ASR-1.7B惊艳效果:戏曲唱段(京剧/越剧)台词精准转写
Qwen3-ASR-1.7B惊艳效果:戏曲唱段(京剧/越剧)台词精准转写 你听过AI识别流行歌曲,但你见过AI听懂京剧唱腔吗?传统戏曲的转写,尤其是那些带着独特唱腔、方言和复杂背景音乐的唱段,一直是语音识别…...
NumPy 矩阵核心操作入门
乘法、加法、转置与广播机制入门解析 前言 NumPy 是 Python 生态中数值计算的基石库,而矩阵(数组)操作是线性代数、数据分析、机器学习等领域的核心基础。本文将系统梳理 NumPy 中最常用的矩阵操作,包含矩阵乘法、矩阵加法、转置矩…...
OpenClaw+Phi-3-mini-128k-instruct内容处理:从爬虫到发布的自动化流水线
OpenClawPhi-3-mini-128k-instruct内容处理:从爬虫到发布的自动化流水线 1. 为什么需要内容处理自动化 作为一个技术博主,我每天需要处理大量信息:从技术社区抓取最新动态、整理成可读性强的文章、再发布到多个平台。这个过程耗时费力&…...
三菱PLC搭配雅马哈四轴机械手在线检测收料案例解析:融合CAD电气图纸、CClink与串口通讯...
三菱plc搭配四轴雅马哈机械手在线检测收料案例程序。 (包涵CAD电气图纸,plc程序,人机界面,机器人程序,BOM表)程序中应用到CClink通讯,232串口通讯,数据采集伺服定位控制。这项目有点…...
数据存储与管理:QmlBook本地存储与SQL集成教程
数据存储与管理:QmlBook本地存储与SQL集成教程 【免费下载链接】qmlbook The source code for the upcoming qml book 项目地址: https://gitcode.com/gh_mirrors/qm/qmlbook QmlBook提供了全面的本地存储解决方案,帮助开发者轻松实现应用数据的持…...
SQL查询语句--EXISTS子查询
EXISTS子查询的逻辑是先查询外层数据,再逐行进行EXISTS子查询。外层查询出的每条记录都执行一EXISTS子查询,EXISTS子查询为TRUE则保留当前记录,为FALSE则不保留。例如:需求:查询选择了课程号C_id为1的学生学号和姓名。…...
《道德经》第九章
本章以持而盈之功成身退为核心,是道家保身、持满、长久的警示章。老子用“持盈、揣锐、富贵而骄”三组世俗常见困境,指出过刚则折、过满则溢、过骄则亡的天道规律,最终以“功成身退,天之道”点破最高处世心法,是全书最…...
