Redis学习笔记16:基于spring data redis及lua脚本通过TTL查询永久有效的key

Redis做为一个缓存服务,个人觉得不应该存在有永久有效的数据,要检索一个存在很久的redis服务器中存在哪些永久有效的key,可以通过lua脚本的方式实现;

一个对springboot redis框架进行重写,支持lettuce、jedis、连接池、同时连接多个集群、多个redis数据库、开发自定义属性配置的开源SDK

xml 复制代码
<dependency>
    <groupId>io.github.mingyang66</groupId>
    <artifactId>emily-spring-boot-redis</artifactId>
    <version>4.4.0</version>
</dependency>

GitHub地址:https://github.com/mingyang66/spring-parent

一、TTL过期时间为-1的lua脚本
lua 复制代码
local success, result = pcall(function()
    -- 获取所有键
    local keys = redis.call('KEYS','*')
    -- 初始化表
    local result = {}
    for i, key in ipairs(keys) do
        -- 获取键的过期时间
        local ttl = redis.call('TTL', key)
        if ttl == -1 then
            -- 在table的数组部分指定位置(pos)插入值为value的一个元素. pos参数可选, 默认为数组部分末尾.
            table.insert(result, key)
        end
    end
    return result
end)

if success then
    return result
else
    return result
end

首先通过KEYS指令查询所有的键值,然后循环列表,通过TTL指令获取键值的过期时间,如果过期时间为-1,则将键值添加进列表,最后返回给客户端。

二、spring data redis实现脚本加载并执行
java 复制代码
    /**
     * @param redisTemplate redis 模板工具类
     * @return TTL为-1的键集合列表
     */
    public static List<String> ttlKeys(RedisTemplate redisTemplate) {
        if (StringUtils.isEmpty(LUA_SCRIPT_TTL_KEYS)) {
            LUA_SCRIPT_TTL_KEYS = getLuaScript("META-INF/scripts/ttl_keys.lua");
        }
        RedisScript<List> script = RedisScript.of(LUA_SCRIPT_TTL_KEYS, List.class);
        return (List<String>) redisTemplate.execute(script, SerializationUtils.stringSerializer(), SerializationUtils.stringSerializer(), null);
    }

   public static StringRedisSerializer stringSerializer() {
        return new StringRedisSerializer();
    }

通过lua脚本查询键值数据时需指定key-value的序列化方式为StringRedisSerializer,否则会采用默认的Jackson2JsonRedisSerializer序列化方式,查询结果返回给java端后会抛出序列化异常。

三、控制器
java 复制代码
    @GetMapping("ttl")
    public List<String> ttl(){
        List<String> list = LuaScriptTools.ttlKeys(redisTemplate);
        return list;
    }
相关推荐
记得开心一点嘛1 小时前
Redis封装类
java·redis
短剑重铸之日2 小时前
《7天学会Redis》Day 5 - Redis Cluster集群架构
数据库·redis·后端·缓存·架构·cluster
007php0072 小时前
mySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据
数据库·redis·git·mysql·面试·职场和发展·php
win x3 小时前
Redis 分布式锁
数据库·redis·分布式
胡萝卜的兔5 小时前
ThinkPHP6.0 Redis 延迟队列 + 定时任务 实现超时取消订单完整部署脚本
数据库·redis·缓存
进阶的小名7 小时前
[超轻量级延时队列(MQ)] Redis 不只是缓存:我用 Redis Stream 实现了一个延时MQ(自定义注解方式)
java·数据库·spring boot·redis·缓存·消息队列·个人开发
短剑重铸之日7 小时前
《7天学会Redis》Day 6 - 内存&性能调优
java·数据库·redis·缓存·7天学会redis
DemonAvenger7 小时前
Redis数据迁移与扩容实战:平滑扩展的技术方案
数据库·redis·性能优化
2501_948194987 小时前
RN for OpenHarmony AnimeHub项目实战:人气排行页面开发
redis
qq_318121597 小时前
互联网大厂Java面试故事:支付与金融服务微服务架构、消息队列与AI风控全流程解析
java·spring boot·redis·微服务·kafka·支付系统·金融服务