新手关于 redis 丢数据的问题

2019-03-14 15:02:32 +08:00
 sharkv

问题是这样的: 本人在 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);
10001 次点击
所在节点    Redis
10 条回复
yc8332
2019-03-14 15:31:53 +08:00
不是可以通过 ttl 看设置的过期时间吗? ttl key 看设置的过期时间
Raymon111111
2019-03-14 15:32:37 +08:00
先上服务端看看这个 key 是不是存在
Raymon111111
2019-03-14 15:35:08 +08:00
我解决的话会先定位问题点

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

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

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

...反正分步排查吧
boris1993
2019-03-14 15:41:36 +08:00
同意#3,调查写没写进去,超时有没有设置上,超时时间的单位是什么,确定写操作都正确再检查为啥读不到
sharkv
2019-03-14 16:08:09 +08:00
这个不好贴图。我都试过了,能在 redis 可视化客户端看到数据存在过,然后刷新一段时间就没了。我找到的原因是 redis 里面会自动存入 caches 和 runtime 两条数据,这两个数据一存在我的数据就会丢失。
sharkv
2019-03-14 16:09:08 +08:00
我在 redis 把 caches 和 runtime 删了过段时间它又自动生成了。所以该怎么删。。
sharkv
2019-03-14 16:28:37 +08:00
问题找到了。应该就是被人撞库了,我改了下密码,设置了下 ip 就可以了
boris1993
2019-03-14 16:31:59 +08:00
@sharkv #7 你 Redis......监听公网还不上密码???
cheava
2019-03-14 19:58:52 +08:00
@sharkv #7 这问题还真不在一般的 debug 范围内.....大家都默认了你的 redis 和应用在同一内网......
Leigg
2019-03-14 20:43:25 +08:00
写个脚本,每隔一秒读取一下这个值,set 后马上执行脚本。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/544575

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX