当前位置: 首页 > news >正文

lua入门以及在Redis中的应用

1.基本语法
1.1变量

lua的变量有:无效值nil,布尔值boolean,数字number、字符串string、函数function、自定义类型userdata、线程thread、表table(key-value结构)

1.2循环

数值循环

for i=起始值, 结束值 ,间隔值 do

---options

end

间隔值为1时可以省略。像python里面的range()函数

迭代循环

for k,v in pairs(tb) do

print(k,v)

end

while循环

while(condition)

do

---options

ee

repeat -until

repeat-- statements
until( condition )
1.3条件语句
if(con1) then
-----option--
elseif(con2) then
----option
elseif(con3) then
---option
end
1.4函数的定义
function a(num)print("hello"..num)  //字符串拼接用的 .. 而不是+,1+‘1’=2.0
enda=function()print('a')
end

函数定义默认都全局的,即使是嵌套在其它函数里面,如果想定义局部的函数,需要使用local关键字修饰。

2.lua脚本在redis中的使用

查看redis当前有哪些key没有设置过期时间,内存满的时候可以进行排查

-- 获取所有key的模式(默认为*)
local pattern = ARGV[1] or '*'
local result = {keys = {}, stats = {total = 0, neverexpire = 0}}
local start_time = redis.call('TIME')[1]-- 使用SCAN迭代
local cursor = '0'
repeatlocal reply = redis.call('SCAN', cursor, 'MATCH', pattern)cursor = reply[1]local keys = reply[2]-- 检查每个keyfor _, key in ipairs(keys) doresult.stats.total = result.stats.total + 1local ttl = redis.call('TTL', key)if ttl == -1 thentable.insert(result.keys, key)result.stats.neverexpire = result.stats.neverexpire + 1endend
until cursor == '0'-- 计算执行时间
local end_time = redis.call('TIME')[1]
result.stats.duration = end_time - start_time-- 返回结果
if #result.keys == 0 thenreturn "没有永不过期的key (共扫描: "..result.stats.total.." 个key, 耗时: "..result.stats.duration.."秒)"
elseresult.msg = "找到 "..result.stats.neverexpire.." 个永不过期的key (共扫描: "..result.stats.total.." 个key, 耗时: "..result.stats.duration.."秒)"return result
end--------------------------------
以上内容由AI生成,仅供参考和借鉴

lua脚本实现分布式锁

-- 获取锁
-- KEYS[1]: 锁的key
-- ARGV[1]: 锁的值(通常是客户端唯一标识)
-- ARGV[2]: 过期时间(秒)
local key = KEYS[1]
local value = ARGV[1]
local ttl = tonumber(ARGV[2])-- 尝试设置锁(NX表示key不存在时才设置,EX表示设置过期时间)
local lockSet = redis.call('SET', key, value, 'NX', 'EX', ttl)if lockSet thenreturn true
else-- 检查锁是否是自己持有的(防止误删其他客户端的锁)local currentValue = redis.call('GET', key)if currentValue == value then-- 延长锁的过期时间redis.call('EXPIRE', key, ttl)return trueelsereturn falseend
end
http://www.dtcms.com/a/341153.html

相关文章:

  • 【ElasticSearch实用篇-03】QueryDsl高阶用法以及缓存机制
  • Java程序启动慢,DNS解析超时
  • 基于STM32的APP遥控视频水泵小车设计
  • K8S-Pod资源对象——标签
  • 【AI学习100天】Day08 使用Kimi每天问100个问题
  • 【指纹浏览器系列-绕过cdp检测】
  • 数据预处理:机器学习的 “数据整容术”
  • nginx-下载功能-状态统计-访问控制
  • 【数据结构】线性表——顺序表
  • 循环神经网络(RNN, Recurrent Neural Network)
  • Effective C++ 条款52:写了placement new也要写placement delete
  • 使用acme.sh自动申请AC证书,并配置自动续期,而且解决华为云支持问题,永久免费自动续期!
  • Spring Boot 定时任务与 xxl-job 灵活切换方案
  • 层在init中只为创建线性层,forward的对线性层中间加非线性运算。且分层定义是为了把原本一长个代码的初始化和运算放到一个组合中。
  • B站 韩顺平 笔记 (Day 24)
  • C++ std::optional 深度解析与实践指南
  • 当 AI 开始 “理解” 情绪:情感计算如何重塑人机交互的边界
  • linux报permission denied问题
  • Advanced Math Math Analysis |01 Limits, Continuous
  • uniapp打包成h5,本地服务器运行,路径报错问题
  • PyTorch API 4
  • 使数组k递增的最少操作次数
  • 路由器的NAT类型
  • 确保测试环境一致性与稳定性 5大策略
  • AI 效应: GPT-6,“用户真正想要的是记忆”
  • 获取本地IP地址、MAC地址写法
  • SQL 中大于小于号的表示方法总结
  • Bitcoin有升值潜力吗
  • 《代码沙盒深度实战:iframe安全隔离与实时双向通信的架构设计与落地策略》
  • 在SQL中使用大模型时间预测模型TimesFM