redis存储数据优化
2020-11-27 本文已影响0人
自由主义者
因为redis储存数据默认使用的时jdkjson,有两大问题:
No1:存储的Object(Entity)需要实现序列化接口(implements Serializable);
No2:存储的数据中有一些其他编码,导致可读性差;
所以为了解决以上的两个问题:
将默认的jdkjson改为jsckson2json。代码如下:
package mall.config;
import client.AccessToken;
import client.RedisAccessTokenCache;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
@Configuration
public class redisConfig {
@Autowired
private RedisTemplate<String, AccessToken> redisTemplate;
@Bean
public RedisTemplate<String, AccessToken> redisTemplate(RedisConnectionFactory cf) {
RedisTemplate<String, AccessToken> redisTemplate = new RedisTemplate<String, AccessToken>();
redisTemplate.setConnectionFactory(cf);
GenericJackson2JsonRedisSerializer jackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
return redisTemplate;
}
@Bean
public RedisAccessTokenCache redisAccessTokenCache(){
RedisAccessTokenCache redisAccessTokenCache = new RedisAccessTokenCache();
redisAccessTokenCache.setRedisTemplate(redisTemplate);
return redisAccessTokenCache;
}
}