传递对象数组到Redis Lua脚本的最佳方式
2019-8-30 10:44:55
收藏:0
阅读:173
评论:1
问题
如何最佳实践地传递对象数组到Lua脚本中?有没有比在脚本中将对象转换为JSON并使用cjson进行解析更好的方法?
更多背景
我有一个流式应用程序,它在Redis中保留其状态。每秒钟,我们会获得5-100个事件,所有操作都在单个事务中完成,以提高性能,例如以下操作:
RedisCommands<String,String> cmd = getOrCreateRedisClient();
cmd.multi();
for (Event event: listOfEvents) {
cmd.sadd("users", event.getUserId());
cmd.sadd("actions", event.getActionId());
cmd.incrbyfloat("users:" + event.getUserId(), event.getImpact());
}
cmd.exec();
现在我必须将这个逻辑移动到Lua脚本中。我想传递一个事件数组到Lua脚本中也会更快,而不是进行多达100次的脚本调用(每个事件一次)。_ 我对吗?传递事件列表到Lua脚本的最佳方式是什么?_
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 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 代码?

这取决于...
如果您的逻辑在将来不会改变,即您仅使用事件的
用户 id,操作 id和影响,则可以将这三个元素传递给 Lua:redis-cli --eval your-script.lua , userid1 actionid1 impact1 userid2 actionid2 impact2 userid3 actionid3 impact3在这种情况下,您不需要将事件对象转换为 JSON 字符串,Lua 脚本也不需要解析 JSON 字符串,因此应该更快。
然而,如果您的逻辑将来可能会改变,即您可能需要使用事件的其他成员,最好将事件对象转换为 JSON 字符串,并将 JSON 字符串数组传递给 Lua 脚本:
redis-cli --eval your-script.lua , {json1} {json2} {json3}这样这些更改对您的代码是透明的,而您只需要更改 Lua 脚本就可以了。