SpringBoot系列:Spring Boot集成Spring Cache,使用RedisCache

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

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;

}

总结

大型分布式系统犹如一个生命,系统中各个服务犹如骨骼,其中的数据犹如血液,而Kafka犹如经络,串联整个系统。这份Kafka源码笔记通过大量的设计图展示、代码分析、示例分享,把Kafka的实现脉络展示在读者面前,帮助读者更好地研读Kafka代码。

麻烦帮忙转发一下这篇文章+关注我

就这一次!拼多多内部架构师培训Kafka源码笔记(现已绝版)

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
码分析、示例分享,把Kafka的实现脉络展示在读者面前,帮助读者更好地研读Kafka代码。

麻烦帮忙转发一下这篇文章+关注我

[外链图片转存中…(img-lxZjw2q9-1714670752804)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值