资讯专栏INFORMATION COLUMN

springboot注解方式使用redis缓存

Muninn / 3593人阅读

摘要:引入依赖库在中引入依赖库,如下注解使用自定义应用到写数据的方法上,如新增修改方法即应用到移除数据的方法上,如删除方法提供的上下文数据提供了一些供我们使用的上下文数据,下表直接摘自官方文档名字位置描述示例对象当前被调用的方法

引入依赖库

在pom中引入依赖库,如下

</>复制代码

  1. org.springframework.boot
  2. spring-boot-starter-data-redis
  3. redis.clients
  4. jedis
注解使用

</>复制代码

  1. @Cacheable
  2. @Cacheable("product")
  3. @Cacheable(value = {"product","order"}, key = "#root.targetClass+"-"+#id")
  4. @Cacheable(value = "product", key = "#root.targetClass+"-"+#id")
  5. 自定义cacheManager
  6. @Cacheable(value = "product", key = "#root.targetClass+"-"+#id” cacheManager="cacheManager")
  7. @CachePut
  8. 应用到写数据的方法上,如新增/修改方法
  9. @CachePut(value = "product", key = "#root.targetClass+"-"+#product.id")
  10. @CacheEvict
  11. 即应用到移除数据的方法上,如删除方法
  12. @CacheEvict(value = "product", key = "#root.targetClass+"-"+#id")
  13. 提供的SpEL上下文数据

Spring Cache提供了一些供我们使用的SpEL上下文数据,下表直接摘自Spring官方文档:

名字 位置 描述 示例
methodName root对象 当前被调用的方法名 #root.methodName
method root对象 当前被调用的方法 #root.method.name
target root对象 当前被调用的目标对象 #root.target
targetClass root对象 当前被调用的目标对象类 #root.targetClass
args root对象 当前被调用的方法的参数列表 #root.args[0]
caches root对象 当前方法调用使用的缓存列表(如@Cacheable(value={"cache1", "cache2"})),则有两个cache #root.caches[0].name
argument name 执行上下文 当前被调用的方法的参数,如findById(Long id),我们可以通过#id拿到参数 #user.id
result 执行上下文 方法执行后的返回值(仅当方法执行之后的判断有效,如‘unless’,"cache evict"的beforeInvocation=false) #result
自定义Cache配置

</>复制代码

  1. @Configuration
  2. @EnableCaching
  3. public class RedisConfig extends CachingConfigurerSupport {
  4. /**
  5. * 自定义redis key值生成策略
  6. */
  7. @Bean
  8. @Override
  9. public KeyGenerator keyGenerator() {
  10. return (target, method, params) -> {
  11. StringBuilder sb = new StringBuilder();
  12. sb.append(target.getClass().getName());
  13. sb.append(method.getName());
  14. for (Object obj : params) {
  15. sb.append(obj.toString());
  16. }
  17. return sb.toString();
  18. };
  19. }
  20. @Bean
  21. public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
  22. ObjectMapper om = new ObjectMapper();
  23. om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
  24. om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
  25. //redis序列化
  26. Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
  27. jackson2JsonRedisSerializer.setObjectMapper(om);
  28. StringRedisTemplate template = new StringRedisTemplate(factory);
  29. template.setValueSerializer(jackson2JsonRedisSerializer);
  30. template.afterPropertiesSet();
  31. return template;
  32. }
  33. /**
  34. * 自定义CacheManager
  35. */
  36. @Bean
  37. public CacheManager cacheManager(RedisTemplate redisTemplate) {
  38. //全局redis缓存过期时间
  39. RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofDays(1));
  40. RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisTemplate.getConnectionFactory());
  41. return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);
  42. }
  43. }

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/62021.html

相关文章

  • java并发编程学习20--基于springboot的秒杀系统实现2--redis缓存

    摘要:在查询的服务方法上添加如下注解表明该方法的返回值需要缓存。当被缓存的数据发生改变,缓存需要被清理或者修改,这里使用如下注解清除指定的缓存。事务是一个原子操作,所有的缓存,消息,这种非强一致性要求的操作,都应该在事务成功提交后执行。 【为什么使用redis 性能极高,redis能读的速度是110000次/s,写的速度是81000次/s 丰富的数据类型,redis支持二进制案例的 Str...

    bovenson 评论0 收藏0
  • Redis详解 - SpringBoot整合RedisRedisTemplate和注解两种方式的使

    摘要:和注解的方法返回值要一致删除缓存在需要删除缓存的方法上加注解,执行完这个方法之后会将中对应的记录删除。代表返回值,意思是当返回码不等于时不缓存,也就是等于时才缓存。返回值特定值如果被设置了如果没有被设置例子自动将对应到并且返回原来对应的。 本文主要讲 Redis 的使用,如何与 SpringBoot 项目整合,如何使用注解方式和 RedisTemplate 方式实现缓存。最后会给一个用...

    SexySix 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<