问题是这样的: 本人在 springboot 项目中加入了 redis,并且能够存取 redis 中的数据。 我设置了 300s 的有效时间,我一直用 redis-client 刷新数据的有效时间, 但是它时间还没到数据就消失了,报的错误 key not exist: [email protected]
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);
1
yc8332 2019-03-14 15:31:53 +08:00
不是可以通过 ttl 看设置的过期时间吗? ttl key 看设置的过期时间
|
2
Raymon111111 2019-03-14 15:32:37 +08:00
先上服务端看看这个 key 是不是存在
|
3
Raymon111111 2019-03-14 15:35:08 +08:00 2
我解决的话会先定位问题点
1. set 这个方法的有效性. 调用了 set 之后服务端能否看见这个, 如果不可以, 先解决 set 写的不对的问题. 2. 如果 set 没问题, 那么再看 set 上过期时间是不是正确的, set 完之后上服务端看看过期时间是不是能对上. 3. 如果 set 整个没问题, 就检查 get 方法的毛病... ...反正分步排查吧 |
4
boris1993 2019-03-14 15:41:36 +08:00 via Android
同意#3,调查写没写进去,超时有没有设置上,超时时间的单位是什么,确定写操作都正确再检查为啥读不到
|
5
sharkv OP 这个不好贴图。我都试过了,能在 redis 可视化客户端看到数据存在过,然后刷新一段时间就没了。我找到的原因是 redis 里面会自动存入 caches 和 runtime 两条数据,这两个数据一存在我的数据就会丢失。
|
6
sharkv OP 我在 redis 把 caches 和 runtime 删了过段时间它又自动生成了。所以该怎么删。。
|
7
sharkv OP 问题找到了。应该就是被人撞库了,我改了下密码,设置了下 ip 就可以了
|
9
cheava 2019-03-14 19:58:52 +08:00
@sharkv #7 这问题还真不在一般的 debug 范围内.....大家都默认了你的 redis 和应用在同一内网......
|
10
Leigg 2019-03-14 20:43:25 +08:00 via iPhone
写个脚本,每隔一秒读取一下这个值,set 后马上执行脚本。
|