python使用redis存储时序数据

python 复制代码
import redis

def ts_demo():
    """时序数据存储RedisTimeSeries测试"""
    # 连接到Redis
    r = redis.Redis(host='localhost', password="xxxx", port=63790, db=0)
    r1 = r.ts()
    # print(r1.get("ts_key"))
    # print(r.exists('ts_key'))
    # # 清空键值
    # r.delete("ts_key1111")
    # print(r1.range("ts_key1111", '-', '+'))
    # 设置过期时间为10s,即timestamp的时间相比当前时间相差10s以上的数据就不存在于这个key中。
    r1.create(key="ts_key", retention_msecs=10000, duplicate_policy="last")
    r1.add(key="ts_key1111", timestamp='*', value=1) # *表示取当前时间
    r1.add(key="ts_key", timestamp='*', value=2)
    r1.add(key="ts_key", timestamp='*', value=3)
    r1.add(key="ts_key", timestamp='*', value=4)
    time.sleep(5)
    r1.add(key="ts_key", timestamp='*', value=5)
    r1.add(key="ts_key", timestamp='*', value=6)
    r1.add(key="ts_key", timestamp='*', value=7)
    r1.add(key="ts_key", timestamp='*', value=8)
    r1.add(key="ts_key", timestamp='*', value=9)
    r1.add(key="ts_key", timestamp='*', value=10)
    r1.add(key="ts_key", timestamp='*', value=11)

    print(r1.get("ts_key")) # 获取该key下的时间最大的数据
    print(r1.range("ts_key", '-', '+')) # 获取该key下的所有数据
    time.sleep(5)
    print(r1.range("ts_key", '-', '+')) 
    
if __name__ == '__main__':
    ts_demo()

存在的问题

可能会报错redis没有RedisTimeSeries扩展模块,详细信息可以参考redis官网https://redis.io/docs/latest/develop/data-types/timeseries/

也可以参考如下:
https://blog.csdn.net/LinkSLA/article/details/123040789

查看redis中是否有时间序列数据库模块可以参考如下代码:

python 复制代码
# 连接到Redis
r = redis.StrictRedis(host='localhost', password="xxxx", port=63790, db=0)

# 获取Redis的信息
info = r.info()
print(info)
# 检查是否加载了时间序列数据库模块
if 'redis_modules' in info and 'name' in info['redis_modules']:
    for module in info['redis_modules']:
        if module['name'] == 'timeseries':
            print("Redis Time Series Database module is enabled.")
else:
    print("Redis Time Series Database module is not enabled.")
相关推荐
2401_82422269几秒前
Python测试代码如何实现自解释_使用pytest描述性命名规范
jvm·数据库·python
桔筐2 分钟前
Redis 无锁化库存扣减方案(INCR + SETNX 实现,高并发不超卖)
java·redis
接着奏乐接着舞3 分钟前
springboot 常用注解
spring boot·后端·python
woxihuan1234563 分钟前
MySQL 中高效存储与查询时间数据的最佳实践
jvm·数据库·python
2301_809204704 分钟前
如何用 structuredClone 原生函数实现复杂对象深拷贝
jvm·数据库·python
2401_898717665 分钟前
Golang Gin如何定义路由和路由组_Golang Gin路由教程【实用】
jvm·数据库·python
甄心爱学习6 分钟前
【项目实训(个人6)】
人工智能·python·个人开发
ㄟ留恋さ寂寞7 分钟前
Golang怎么用unsafe获取结构体大小_Golang如何用Sizeof查看类型占用的字节数【方法】
jvm·数据库·python
IT策士8 分钟前
Python 中间件系列:kafka学习
python·中间件·kafka
水木流年追梦8 分钟前
大模型入门-应用篇2-RAG (检索增强生成):从原理到 Python 实战
开发语言·python·算法·prompt