Skip to content

Commit

Permalink
♻️ 调整缓存由序列化改为 json 格式,[ISSUE#57](xkcoding#57)
Browse files Browse the repository at this point in the history
  • Loading branch information
xkcoding committed Oct 10, 2019
1 parent 23a5cba commit ddb3c50
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 3 deletions.
14 changes: 13 additions & 1 deletion spring-boot-demo-cache-redis/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,18 @@ public class RedisConfig {
template.setConnectionFactory(redisConnectionFactory);
return template;
}

/**
* 配置使用注解的时候缓存配置,默认是序列化反序列化的形式,加上此配置则为 json 形式
*/
@Bean
public CacheManager cacheManager(RedisConnectionFactory factory) {
// 配置序列化
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig();
RedisCacheConfiguration redisCacheConfiguration = config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())).serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));

return RedisCacheManager.builder(factory).cacheDefaults(redisCacheConfiguration).build();
}
}
```

Expand Down Expand Up @@ -327,7 +339,7 @@ public class UserServiceTest extends SpringBootDemoCacheRedisApplicationTests {
*/
@Test
public void getAfterSave() {
userService.saveOrUpdate(new User(4L, "user4"));
userService.saveOrUpdate(new User(4L, "测试中文"));

User user = userService.get(4L);
log.debug("【user】= {}", user);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,17 @@

import org.springframework.boot.autoconfigure.AutoConfigureAfter;
import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
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.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.io.Serializable;
Expand Down Expand Up @@ -41,4 +46,16 @@ public RedisTemplate<String, Serializable> redisCacheTemplate(LettuceConnectionF
template.setConnectionFactory(redisConnectionFactory);
return template;
}

/**
* 配置使用注解的时候缓存配置,默认是序列化反序列化的形式,加上此配置则为 json 形式
*/
@Bean
public CacheManager cacheManager(RedisConnectionFactory factory) {
// 配置序列化
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig();
RedisCacheConfiguration redisCacheConfiguration = config.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())).serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));

return RedisCacheManager.builder(factory).cacheDefaults(redisCacheConfiguration).build();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ public void getTwice() {
*/
@Test
public void getAfterSave() {
userService.saveOrUpdate(new User(4L, "user4"));
userService.saveOrUpdate(new User(4L, "测试中文"));

User user = userService.get(4L);
log.debug("【user】= {}", user);
Expand All @@ -62,4 +62,4 @@ public void deleteUser() {
userService.delete(1L);
}

}
}

0 comments on commit ddb3c50

Please sign in to comment.