luttuce(RedisTempate)实现hash expire lua脚本

话不多说先放脚本:

bash 复制代码
local argv = ARGV
local length = #argv
if length > 0 then  local unpackArgs = {}
for i = 1, length - 1 do
 table.insert(unpackArgs, argv[i])
end
if redis.call('exists', KEYS[1]) == 1 then
	redis.call('del', KEYS[1])
	redis.call('hset', KEYS[1], unpack(unpackArgs))
	redis.call('expire', KEYS[1], argv[length])
	return 1
else
	redis.call('hset', KEYS[1], unpack(unpackArgs))
	redis.call('expire', KEYS[1], ARGV[#ARGV])
	return 2
end
end

2.直接String 执行LUA脚本

bash 复制代码
  /**
     *  lua 脚本 实现物料key 的赋值
     * @param hashKey 物料key
     * @param fieldsAndValues lua 脚本参数
     * @return
     */
    public Long insertIntoHashWithExpireTime(String hashKey, Object... fieldsAndValues) {
        Long result = null;
        // unpack(ARGV)在Lua中是用来将数组解包成一系列单独的参数。
        // ARGV[#ARGV]获取的是传递给脚本的最后一个参数(在 Lua 中,# 操作符用于获取表中的元素数量。因此,ARGV[#ARGV] 将返回 ARGV 表中的最后一个元素。)
        // 请求案例:insertIntoHashWithExpireTimeIfKeyExists("myHash", "field1", "value1", "field2", "value2", 60);
        String luaScript =
                            "\nlocal argv = ARGV \n" +
                            "local length = #argv \n"+
                            // 将1 - n-1 的入参写入新的数组
                            "if length > 0 then  local unpackArgs = {} \n"  +
                                    "for i = 1, length - 1 do  \n" +
                                    " table.insert(unpackArgs, argv[i]) \n" +
                            "end\n" +
                            "if redis.call('exists', KEYS[1]) == 1 then \n" +
                                "\tredis.call('del', KEYS[1]) \n" +
                                "\tredis.call('hset', KEYS[1], unpack(unpackArgs)) \n" +
                                "\tredis.call('expire', KEYS[1], argv[length]) \n" +
                                "\treturn 1  \n" +
                            "else \n" +
                                "\tredis.call('hset', KEYS[1], unpack(unpackArgs)) \n" +
                                "\tredis.call('expire', KEYS[1], argv[length]) \n" +
                                "\treturn 2\n" +
                            "end \n" +
                            "end ";
        log.info("luaScript:{}", luaScript);
        try {
            DefaultRedisScript<Long> redisScript = new DefaultRedisScript<>();
            redisScript.setResultType(Long.class);//返回类型是Long
            redisScript.setScriptText(luaScript);
            result = redisTemplate.execute(redisScript, Arrays.asList(hashKey), fieldsAndValues);
            log.debug("redisEVALLuaScript result :{}", result);
        } catch (Exception e) {
            e.printStackTrace();
            log.error("e:", e);
        }
        return result;
    }
bash 复制代码
    @Test
    public void testLua(){
        String hashKey = "testHash";
        String field1 = "test3";
        String value1 = "vv1";
        String field2 = "test4";
        String value2 = "vv2";
        int expireTime = 10000;

        // 插入数据并设置过期时间
        redisUtils.insertIntoHashWithExpireTime(hashKey, field1, value1, field2, value2,expireTime);
    }

最终结果:

相关推荐
星落zx6 分钟前
Spring Boot 多模型集成:优雅调用全球主流大模型
人工智能·spring boot·chatgpt
yyxx41212315 分钟前
上海企业如何选择专业的钉钉服务商
java·大数据·人工智能·钉钉
一杯奶茶¥26 分钟前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
重生之后端学习30 分钟前
Java入门
java·开发语言·职场和发展
碧海蓝天202235 分钟前
C++法则24:在标准 C++ 中,没有任何可移植的方式判断指针 T* pt 指向的内存位置是否已经 构造了对象,程序员必须手动跟踪哪些元素已构造。
java·开发语言·c++
один but you1 小时前
const和constexpr常量表达式
java·前端·javascript
码云数智-大飞1 小时前
RAII 与智能指针深度拆解
java·前端·算法
云烟成雨TD1 小时前
Agent Scope Java 2.x 系列【19】Harness:从零搭建 MySQL 文件系统
java·人工智能·agent
qq3621967051 小时前
阿里裁员新消息(2026最新动态汇总)
java·开发语言·前端
a1117761 小时前
“黑夜流星“个人引导页 网页html
java·前端·html