phpredis执行LUA脚本示例代码(redis脚本缓存 支持持久化)太疯狂了

随心笔谈9个月前发布 admin
202 00
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买

文章摘要

这篇文章介绍了如何使用Lua脚本与Redis交互,通过Redis的集合操作实现对特定关键字的管理。具体来说,作者提取了KEYS中的不同关键字类型(kw、lrkw、nkw),将它们分别存储到Redis的集合中。如果这些关键字集合不为空,作者还使用Redis的"sinter"命令计算它们的交集。最后,作者将所有结果存储到一个名为"cache_key"的Redis集合中,并使用"expire"命令将该集合的缓存时间设置为600秒,同时返回该集合的大小。整篇内容简明扼要地展示了Redis与Lua脚本的结合使用,以及如何高效管理Redis缓存。


$lua=<<<EOT
local kws={}
local lrkws={}
local nkws={}
local kw_ids={}
local lr_ids={}
local n_ids={}

for kw in string.gmatch(KEYS[1], “[^|]+”) do
table.insert(kws, “kw:”..kw)
end
for kw in string.gmatch(KEYS[2], “[^|]+”) do
table.insert(lrkws, “lrkw:”..kw)
end
for kw in string.gmatch(KEYS[3], “[^|]+”) do
table.insert(nkws, “nkw:”..kw)
end

if #kws > 0 then
kw_ids=redis.call(‘sinter’, unpack(kws))
end
if #lrkws > 0 then
lr_ids=redis.call(‘sinter’, unpack(lrkws))
end
if #nkws > 0 then
n_ids=redis.call(‘sinter’, unpack(nkws))
end
local cache_key=ARGV[1]

for _, v in ipairs(kw_ids) do
redis.call(‘sadd’, cache_key, v)
end
for _, v in ipairs(lr_ids) do
redis.call(‘sadd’, cache_key, v)
end
for _, v in ipairs(n_ids) do
redis.call(‘sadd’, cache_key, v)
end
redis.call(‘expire’, cache_key, 600)
return redis.call(‘scard’, cache_key)
EOT;

$ret=$redis->eval($lua, array(“你好|谢谢”, “”, “hello”, “cache_key”), 3);
echo $ret;

© 版权声明

相关文章