您好,登錄后才能下訂單哦!
這篇文章主要介紹了SpringBoot整合Redis之怎么編寫RedisConfig的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇SpringBoot整合Redis之怎么編寫RedisConfig文章都會有所收獲,下面我們一起來看看吧。
首先看看我們直接使用RedisTemplate的問題,我們就知道RedisConfig要包含什么了,我們在RedisConfig需要規定好根據不同的查詢生成的key,key和value的序列化和反序列化
我們在RedisConfig中配置的自定義方法,最終通過注解引用的就是我們自定義的方法
RedisConfig.java :
對redis提供的兩個Template的序列化配置
/** * @Author: JCccc * @CreateTime: 2018-09-11 * @Description: */ import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.databind.ObjectMapper; 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.core.StringRedisTemplate; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; @Configuration @EnableCaching public class RedisConfig { @Bean public CacheManager cacheManager(RedisConnectionFactory connectionFactory) { RedisCacheConfiguration cacheConfiguration = defaultCacheConfig() .disableCachingNullValues() .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new Jackson2JsonRedisSerializer(Object.class))); return RedisCacheManager.builder(connectionFactory).cacheDefaults(cacheConfiguration).build(); // RedisCacheManager rcm=RedisCacheManager.create(connectionFactory); // // return rcm; } @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(factory); 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); //序列化設置 ,這樣為了存儲操作對象時正常顯示的數據,也能正常存儲和獲取 redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(jackson2JsonRedisSerializer); redisTemplate.setHashKeySerializer(new StringRedisSerializer()); redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer); return redisTemplate; } @Bean public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory factory) { StringRedisTemplate stringRedisTemplate = new StringRedisTemplate(); stringRedisTemplate.setConnectionFactory(factory); return stringRedisTemplate; } }
補充
redisconfig配置與使用
配置類:
@Configuration // 定義一個配置類 public class RedisConfig { //object object /* * 用于redisApi * */ @Bean public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { RedisTemplate<Object, Object> template = new RedisTemplate(); template.setConnectionFactory(redisConnectionFactory); // 使用JSON格式序列化對象,對緩存數據key和value進行轉換 Jackson2JsonRedisSerializer jacksonSeial = new Jackson2JsonRedisSerializer(Object.class); // 解決查詢緩存轉換異常的問題 ObjectMapper om = new ObjectMapper(); om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); jacksonSeial.setObjectMapper(om); // 設置RedisTemplate模板API的序列化方式為JSON template.setDefaultSerializer(jacksonSeial); return template; } }
使用方式:
1. 業務類中進行注入:
@Autowired RedisTemplate redisTemplate;
2. 使用redisTemplate的內置方法:
2.1 獲取redis中的數據
Object object = redisTemplate.opsForValue().get("course_" + id);
2.2 插入數據
redisTemplate.opsForValue().set("course_" + id, course, 1, TimeUnit.DAYS);
關于“SpringBoot整合Redis之怎么編寫RedisConfig”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“SpringBoot整合Redis之怎么編寫RedisConfig”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。