Redis时间序列,LUA实现滚动总和
2020-12-31 13:26:49
收藏:0
阅读:110
评论:2
我有一个时间序列,我想要计算一个滚动总和。我的想法(可能已经不够优化)是编写一个脚本来计算每个数据点,然后在Python中运行一个管道。
我困惑于脚本。
返回
redis.call('TS.ADD',
KEYS[1],
ARGV[1],
redis.call('TS.RANGE',
'ts:1s',
ARGV[2],
ARGV[3],
'AGGREGATION',
'sum',
120000)[1][2])
当我在redis-cli中使用args 1 ts:rolling:sum 1609011855000 1609013655000 EVAL时,它返回:
(错误)ERR运行脚本时出错(调用f_e57a3287fc55b792d33ba7c21e3aae715c5ee3e5):@user_script:1: @user_script: 1:Lua redis()命令参数必须是字符串或整数
第一个调用
eval “return redis.call( 'TS.RANGE',
'ts:1s',
ARGV [2],
ARGV [3],
'AGGREGATION',
'sum',
120000)“ 0 1609011855000 1609013655000
给了我
1)1)(整数)1609012800000
2)2057
奇怪的是,我可以加上时间戳但是不能加上值。
我以前从未接触过LUA,所以我可能在这里漏了完全明显的东西
我不确定我清楚表达了什么,所以这里在Python中,使用pandas,我想要实现的是:
import pandas as pd
df = pd.DataFrame(my_data_granular_to_1s, columns=['date','val']).set_index(date)
df.val.resample('1s').sum().rolling(120).sum() # <= that
点赞
用户17696778
为什么
可以通过 v[1][2]["ok"]在lua中访问2057。
如果你使用内置的调试器,这非常清楚。
以下是一个示例:
- test.lua
redis.pcall("TS.ADD", KEYS[1], "*", 1, "ON_DUPLICATE", "SUM")
local reply = redis.call("TS.RANGE", KEYS[1], "-", "+")
redis.debug(reply)
redis.debug(reply[1][2]["ok"])
redis-cli -h your-host -p your-port --ldb --eval ./test.lua test:key
-> 2 redis.pcall("TS.ADD", KEYS[1], "*", 1, "ON_DUPLICATE", "SUM")
lua debugger> s
<redis> TS.ADD test:key * 1 ON_DUPLICATE SUM
<reply> 1655798188752
* Stopped at 4, stop reason = step over
-> 4 local reply = redis.call("TS.RANGE", KEYS[1], "-", "+")
lua debugger> s
<redis> TS.RANGE test:key - +
<reply> [[1655798188752,"+1"]]
* Stopped at 5, stop reason = step over
-> 5 redis.debug(reply)
lua debugger> s
<debug> line 5: {{1.6558e+12; {["ok"]="1"}}}
* Stopped at 8, stop reason = step over
-> 8 redis.debug(reply[1][2]["ok"])
lua debugger> s
<debug> line 8: "1"
* Stopped at 9, stop reason = step over
-> 9 <out of range source code line>
lua debugger> s
(nil)
(Lua debugging session ended -- dataset changes rolled back)
正如你所看到的,TS.RANGE返回一个嵌套表:
{{1.6558e+12; {["ok"]="1"}}}
所以我要使用以下代码来获得它的结果:
reply[1][2]["ok"]
2022-06-21 08:00:03
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

结果是
1) 1) (integer) 1609012800000 2) 2057通过
v[1][2]["ok"]可以在lua中访问2057。从我的“今天第一次接触lua”的角度来看,这看起来很像一个bug。在向团队报告问题之前,我将更加熟悉它,以确保我没有错过任何显而易见的问题。