Redis, как хранить значения как JSON - PullRequest
0 голосов
/ 04 ноября 2019

Я использую Redis в качестве хранилища кэширования в своем приложении. Для этого я использую следующую конфигурацию redis:

@Configuration
@EnableCaching
public class SpringRedisConfig {
@Bean
public JedisConnectionFactory connectionFactory() {
    JedisConnectionFactory connectionFactory = new JedisConnectionFactory();
    connectionFactory.setHostName("localhost");
    connectionFactory.setPort(6379);
    return connectionFactory;
}

@Bean
public RedisTemplate<String, Object> redisTemplate() {
    RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
    redisTemplate.setConnectionFactory(connectionFactory());
    redisTemplate.setKeySerializer(new StringRedisSerializer());


    RedisSerializer<String> redisSerializer = new StringRedisSerializer();

    Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
    ObjectMapper om = new ObjectMapper();
    om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
    om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
    jackson2JsonRedisSerializer.setObjectMapper(om);

    //template.setConnectionFactory(factory);
    redisTemplate.setKeySerializer(redisSerializer);
    redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
    redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);


    return redisTemplate;
}
}

и в своих сервисах для хранения данных в кеше я использую @Cacheable следующим образом:

@Cacheable(value = "institute_detail_cache", key = "'inst_'+#instituteId")
public Map<String, String> getDetailsFromCache(Long instituteId) {
    log.info("not found in cache.....");

    Map<String, String> map = new HashMap<>();
    map.put("name", "kayv");
    map.put("age", "20");

    return map;
}

Код работаетштраф и хранение данных в кеше как объект. Вот значение, которое я получил от redis cli:

enter image description here

Но мое требование - хранить данные (значение) как json с ключом-значениемпар. Вот почему я использовал Jackson2JsonRedisSerializer для сериализации значений.

Кто-нибудь может подсказать, что я делаю неправильно?

И что мне нужно реализовать, чтобы мои классы сохранялись как json, а не как карта, как я использовал в этом примере?

1 Ответ

0 голосов
/ 05 ноября 2019

Использование класса GenericJackson2JsonRedisSerializer вместо класса Jackson2JsonRedisSerializer решило мою проблему для меня.

Создан новый класс конфигурации (RedisCacheManagerConfiguration.java) вместо старого SpringRedisConfig.java.

@Configuration
@EnableCaching
public class RedisCacheManagerConfiguration {

    @Autowired
    private RedisConnectionFactory redisConnectionFactory;

    @Bean
    public CacheManager redisCacheManager() {
        RedisSerializationContext.SerializationPair<Object> jsonSerializer =
                RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer());

        return RedisCacheManager.RedisCacheManagerBuilder
                .fromConnectionFactory(redisConnectionFactory)
                .cacheDefaults(
                        RedisCacheConfiguration.defaultCacheConfig()
                                .entryTtl(Duration.ofDays(1))
                                .serializeValuesWith(jsonSerializer)
                )
                .build();
    }

}
...