| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> Redis核心技术与实战-学习笔记(十四):时间序列数据 -> 正文阅读 |
|
[大数据]Redis核心技术与实战-学习笔记(十四):时间序列数据 |
一.时间序列数据时间序列数据:没有严格的关系模型,记录的信息可以表示成键和值的关系。 (例如,一个设备ID对应一条记录); 时间序列数据的读写特点
写入特点简单,插入数据快,时间复杂度低,尽量避免阻塞。 时间序列数据的"读"操作特点:
基于Hash和Sorted Set保存时间序列数据Hsah和sorted set组合实现方式 好处:
缺点:使用了两种类型保存 为什么保存时间序列数据,需要同时使用两种类型
?将时间戳作为Hash集合的key,把记录设备状态值作为Hash集合的value。 ?使用:查询某个时间点或多个时间点上温度数据,直接使用HGET或HMGET命令。
Hash类型实现单键查询简单,但是,不支持对数据进行范围查询。
Sorted Set? ? ? 目的: 支持按时间戳范围的查询 ,可以根据元素的权重分数来排序 ? ? ? 实现:把时间戳作为Sorted Set集合的元素分数,把时间点上记录的数据作为元素本身。 ? ? ? 以保存设备温度的时间序列数据为例: ?ZRANGEBYSCORE命令:? ? ? ? ? ? ?根据输入的最大时间戳和最小时间戳来查询时间范围内的温度值? ? ? ? ? ? ?例如:查询2020-08-03 09:07到? ? ?09:10温度值
同时使用Hash和sorted Set,满足单个时间点和一个时间范围内数据查询的需求。 如何保证写入Hash和Sorted Set是一个原子性操作原子性操作:我们在执行多个写命令操作时候,这些命令要么全部完成,要么都不完成。 为什么要保证原子性:? ? ? ? ?只有保证原子性,才能保证同一时间序列数据,在Hash和Sorted Set中,要么都保存要么都不保存,都和可能出现hash集合中有时间序列数据而sorted set中没有,产生异常数据。 Redis怎么保证原子性操作? ? ? Redis实现简单事务的MULTI和EXEC命令。
? ? 命令1到命令N是在MULTI命令后,EXEC命令前发送的,他们会被一起执行,保证原子性。 ? ? ?使用方式
如何对时间序列数据进行聚合计算??聚合计算使用场景:周期性的统计时间窗口内的数据汇总状态,在实时监控与预警场景下会频繁执行。
RedisTimeSeries
因为RedisTimeSeries不属于Redis的内建功能模块,在使用时,我们需要先把他们的源码单独编译成动态链接库 redistimeseries.so再使用 loadmodule 命令进行加载:
? ? ?当用于时间序列数据存储时,RedisTimeSeries的操作主要有5个:
1. 用 TS.CREATE 命令创建一个时间序列数据集合TS.CREATE命令,我们需要设置时间序列数据集合的key和数据的过期时间(以毫秒为单位)。 此外,我们还可以为数据集合设置标签,来表示数据集合的属性
创建key为device:temperature 数据有效期是600s的时间序列数据集合。 数据创建600s后就会被自动删除。 最后我们给这集合标签属性{device_id:1},表示这个数据集合中记录的是属于设备ID为1的数据。 2.TS.ADD命令插入数据,TS.GET命令读取最新数据
执行 TS.ADD 命令,往 device:temperature 集合中插入了一条数据,记录的是设备在 2020 年 8 月 3 日 9 时 5 分的设备温度;再执行 TS.GET 命令时,就会把刚刚插入的最新数据读取出来。 3.用TS.MGET命令按标签过滤查询数据集合保存多个设备的时间序列数据时,我们通常会把不同设备的数据保存到不同集合中。 此时我们可以使用TS.MGET命令,按照标签查询部分集合中的最新数据, 在使用TS.CREATE 创建数据集合时,我们可以给集合设置标签属性。 当我们进行查询时候,可以在查询条件中对集合标签属性进行匹配,最后的查询结果只返回匹配上的集合中的最新数据。 ? ? ? 假设我们一共用4个集合为4个设备保存时间序列数据,设备的ID号是1,2,3,4,我们在创建集合时,把device_id设置为每个集合的标签。此时,我们就可以使用下列TS.MGET命令以及FILTER设置 (这个配置项用来设置集合标签的过滤条件)。 ? ? ?查询device_id不等于2的所有其他设备的数据集合,并返回各自集合的最新一条数据。 ? ??
4.用TS.RANGE支持需要聚合计算的范围查询
计算2020年8月3日9点5分到12分的数据进行均值计算(按照每 180s 的时间窗口)
总结Redis 提供了两种方案
使用 RedisTimeSeries 模块
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/17 0:09:58- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |