Redis-Lua脚本调试教程

Redis-Lua脚本调试环境配置


文章目录


前言

在分布式系统中要保证数据的原子性,采用Redis+Lua脚本的方式是比较好的选择,但是Lua脚本的调试又是一件很让人头痛的事情。下面我给大家分享一下我目前使用到的一种lua调试方式


一、Lua环境下载

下载lua5.4

  1. 下载路径:https://luabinaries.sourceforge.net/download.html

  2. 点击下载,点击之后要稍微等一会儿才会下载。

  3. 等待下载完毕

  4. 在C 盘中 Program Files文件夹中创建一个名为Lua的文件夹

  5. 把下载的文件解压然后把lua-5.4.8_Win64_bin的文件全部复制到我们创建的Lua文件夹中然后用dllw6_lib这个替换lua里面的dll。

下载 Luarocks

  1. 下载路径:https://luarocks.github.io/luarocks/releases/
  2. 等待下载完毕

    3.在C 盘以外中 Program Files文件夹中创建一个名为Lua的文件夹,把解压出来的
  • lua-5.4.8_Win64_bin
  • lua-5.4.8_Win64_dllw6_lib
  • luarocks-3.12.2-windows-64

文件按顺序复制到Lua文件夹中

环境变量配置

  1. lua 环境变量配置(选中path,然后点击新建,把lua存放的路径写进去,也就是我们上面设置的:D:\Lua)

二、vs code 配置

下载扩展

修改配置

修改vs code中setting.json中的配置,把lua,改为我们下载的lua54

调试项目

项目结构如下,其中lib和lua文件夹为调试所需要的一些包,不用管他。我们只需要把需要调试的lua脚本放入test文件夹里就可以了,然后在main里进行配置调试那个lua脚本,并模拟传入的参数即可

(后面会附赠下载项目的链接)

main脚本中的相关代码

c 复制代码
--#region 定义库路径
package.cpath = "./libs/5.4/lib/?.dll;"
package.path = "./libs/5.4/lua/?.lua;./?.lua"
--#endregion
local redis = require('redis_env')
--#region 连接redis
local params = {
    host = '127.0.0.1',
    port = 6379,
    password = 'redis!2#',
    db = 0,
}
redis.connect(params)
--#endregion
--#region 需要调试的lua脚本文件名称
local test_file = './test/BalanceUpdate.lua'
--#endregion
--#region 模拟脚本所需要的参数
local keys = { 'balance:sp:sms' }
local argv = { '111112', '10', '0', '1' }
--#endregion
--#region 调用进行调试
local result = redis.runLuaFile(test_file, keys, argv)
--#endregion
print(table.unpack(result))

单步调试

选中项目中的main.lua然后点击Debug File

比如我们在脚本中打个断点

在我们进行调试的时候就可以看到里面执行的时候的数据运转详情了

三、 调试项目下载

下载链接:资源下载传送门


总结

以上就是我今日分享的内容,希望对各位有用。

相关推荐
Y001112361 天前
MySQL-进阶
开发语言·数据库·sql·mysql
徒 花1 天前
数据库知识复习01
数据库
mameng19981 天前
Redis遇到热点key如何解决
数据库·redis·缓存
炜宏资料库1 天前
产业集团总部大楼智能化系统项目规划方案精讲
运维·服务器·数据库
嵌入式×边缘AI:打怪升级日志1 天前
从零开始写Linux字符设备驱动:一个不操作硬件的Hello驱动
linux·运维·数据库
搜佛说1 天前
比SQLite更快,比InfluxDB更轻:sfsDb的降维打击
jvm·数据库·物联网·架构·sqlite·边缘计算·iot
LilySesy1 天前
【与AI+】英语day4——数据库与性能优化
数据库·oracle·性能优化·sap·abap·自动翻译
前进的李工1 天前
MySQL角色管理:权限控制全攻略
前端·javascript·数据库·mysql
爱丽_1 天前
MySQL `EXPLAIN`:看懂执行计划、判断索引是否生效与排错套路
android·数据库·mysql
小红的布丁1 天前
Redis 持久化详解:AOF、RDB 与混合持久化如何平衡性能和可靠性
数据库·redis·缓存