首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
拉勾
V2EX  ›  Redis

新手关于 redis 丢数据的问题

  •  
  •   sharkv · 6 天前 · 1019 次点击

    问题是这样的: 本人在 springboot 项目中加入了 redis,并且能够存取 redis 中的数据。 我设置了 300s 的有效时间,我一直用 redis-client 刷新数据的有效时间, 但是它时间还没到数据就消失了,报的错误 key not exist: 18428308415@163.com

    application.yml 中配置了 host、port、password 代码是这样的

    import org.springframework.cache.CacheManager;
    import org.springframework.cache.annotation.EnableCaching;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.data.redis.cache.RedisCacheManager;
    import org.springframework.data.redis.connection.RedisConnectionFactory;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.serializer.RedisSerializer;
    import org.springframework.data.redis.serializer.StringRedisSerializer;
    
    @Configuration
    @EnableCaching
    public class RedisCacheConfig {
        @Bean
        public CacheManager cacheManager(RedisTemplate<?, ?> redisTemplate){
            CacheManager cacheManager = new RedisCacheManager(redisTemplate);
            return cacheManager;
        }
        @Bean
        public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory){
            RedisTemplate<String, String> redisTemplate = new RedisTemplate<String,String>();
            redisTemplate.setConnectionFactory(factory);
            // key 序列化方式;(不然会出现乱码;),但是如果方法上有 Long 等非 String 类型的话,会报类型转换错误;
            // 所以在没有自己定义 key 生成策略的时候,以下这个代码建议不要这么写,可以不配置或者自己实现 ObjectRedisSerializer
            // 或者 JdkSerializationRedisSerializer 序列化方式;
            RedisSerializer<String> redisSerializer = new StringRedisSerializer();// Long 类型不可以会出现异常信息;
            redisTemplate.setKeySerializer(redisSerializer);
            redisTemplate.setHashKeySerializer(redisSerializer);
            return redisTemplate;
        }
    
    }
    
    

    存入数据:

    redisTemplate.opsForValue().set(express, captcha, 300, TimeUnit.SECONDS);
    

    取出数据:

    localCaptcha = redisTemplate.opsForValue().get(key);
    
    10 回复  |  直到 2019-03-14 20:43:25 +08:00
        1
    yc8332   6 天前
    不是可以通过 ttl 看设置的过期时间吗? ttl key 看设置的过期时间
        2
    Raymon111111   6 天前
    先上服务端看看这个 key 是不是存在
        3
    Raymon111111   6 天前   ♥ 2
    我解决的话会先定位问题点

    1. set 这个方法的有效性. 调用了 set 之后服务端能否看见这个, 如果不可以, 先解决 set 写的不对的问题.

    2. 如果 set 没问题, 那么再看 set 上过期时间是不是正确的, set 完之后上服务端看看过期时间是不是能对上.

    3. 如果 set 整个没问题, 就检查 get 方法的毛病...

    ...反正分步排查吧
        4
    boris1993   6 天前 via Android
    同意#3,调查写没写进去,超时有没有设置上,超时时间的单位是什么,确定写操作都正确再检查为啥读不到
        5
    sharkv   6 天前
    这个不好贴图。我都试过了,能在 redis 可视化客户端看到数据存在过,然后刷新一段时间就没了。我找到的原因是 redis 里面会自动存入 caches 和 runtime 两条数据,这两个数据一存在我的数据就会丢失。
        6
    sharkv   6 天前
    我在 redis 把 caches 和 runtime 删了过段时间它又自动生成了。所以该怎么删。。
        7
    sharkv   6 天前
    问题找到了。应该就是被人撞库了,我改了下密码,设置了下 ip 就可以了
        8
    boris1993   6 天前 via Android
    @sharkv #7 你 Redis......监听公网还不上密码???
        9
    cheava   6 天前
    @sharkv #7 这问题还真不在一般的 debug 范围内.....大家都默认了你的 redis 和应用在同一内网......
        10
    Leigg   6 天前 via iPhone
    写个脚本,每隔一秒读取一下这个值,set 后马上执行脚本。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3878 人在线   最高记录 4385   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 16ms · UTC 01:21 · PVG 09:21 · LAX 18:21 · JFK 21:21
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1