前面的章節,講解了[Spring Boot集成Spring Cache]( https://blog.csdn.net/Simple_Yangger/article/details/102693316),Spring Cache已經完成了多種Cache的實現,包括EhCache、RedisCache ...
前面的章節,講解了Spring Boot集成Spring Cache,Spring Cache已經完成了多種Cache的實現,包括EhCache、RedisCache、ConcurrentMapCache等。
這一節我們來看看Spring Cache使用RedisCache。
一、RedisCache使用演示
Redis是一個key-value存儲系統,在web應用上被廣泛應用,這裡就不對其過多描述了。
本章節示例是在Spring Boot集成Spring Cache的源碼基礎上進行改造。源碼地址:https://github.com/imyanger/springboot-project/tree/master/p20-springboot-cache
使用RedisCache作為緩存,我們先引入相關依賴。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--redis依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
然後SpringBoot配置文件中,對redis進行配置。
server:
port: 10900
spring:
profiles:
active: dev
redis:
host: localhost #redis伺服器地址
port: 6379 #redis埠
password: 1234 #redis密碼
timeout: 60000 #連接超時時間
database: 0 #資料庫索引,預設為0
SpringBoot中使用Redis,可以通過Spring Cache的註解,也可以使用RedisTemplate來實現,大部分情況下,因為註解存在一定局限性不夠靈活,一般實際開發中都是使用的RedisTemplate。
附上CacheConfig註入RedisTemplate,如果不需要使用RedisTemplate,直接將@EnableCaching註解加在SpringBoot啟動類上即可。
@Configuration
@EnableCaching
public class CacheConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(connectionFactory);
// 使用Jackson2JsonRedisSerializer來序列化和反序列化redis的value值(預設使用JDK的序列化方式)
Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper mapper = new ObjectMapper();
mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
serializer.setObjectMapper(mapper);
redisTemplate.setValueSerializer(serializer);
// 使用StringRedisSerializer來序列化和反序列化redis的key值
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
}
這樣就可以開始使用RedisCache了,測試代碼與Spring Boot集成Spring Cache一致。
CacheApi介面調用類,方便調用進行測試。
@RestController
@RequestMapping("cache")
public class CacheApi {
@Autowired
private CacheService cacheService;
@GetMapping("get")
public User get(@RequestParam int id){
return cacheService.get(id);
}
@PostMapping("set")
public User set(@RequestParam int id, @RequestParam String code, @RequestParam String name){
User u = new User(code, name);
return cacheService.set(id, u);
}
@DeleteMapping("del")
public void del(@RequestParam int id){
cacheService.del(id);
}
}
CacheService緩存業務處理類,添加緩存,更新緩存和刪除。
@Slf4j
@Service
public class CacheService {
private Map<Integer, User> dataMap = new HashMap <Integer, User>(){
{
for (int i = 1; i < 100 ; i++) {
User u = new User("code" + i, "name" + i);
put(i, u);
}
}
};
// 獲取數據
@Cacheable(value = "cache", key = "'user:' + #id")
public User get(int id){
log.info("通過id{}查詢獲取", id);
return dataMap.get(id);
}
// 更新數據
@CachePut(value = "cache", key = "'user:' + #id")
public User set(int id, User u){
log.info("更新id{}數據", id);
dataMap.put(id, u);
return u;
}
//刪除數據
@CacheEvict(value = "cache", key = "'user:' + #id")
public void del(int id){
log.info("刪除id{}數據", id);
dataMap.remove(id);
}
}
啟動服務進行測試,可以看到緩存功能正常,且打開redis進行查看,也能看到對應的緩存數據。
源碼地址:https://github.com/imyanger/springboot-project/tree/master/p21-springboot-cache-redis