前言

有兴趣的同学,可以看我上一篇文章,然后再过来看会比较清楚点:https://www.cnblogs.com/yhc-910/p/14884678.html

springcache,简单说,就是用来根据条件缓存请求的结果,从而提高整体服务性能和请求速度。

 

springcache有四种注解

@Cacheable:核心注解,请求的返回值会进行缓存,下次请求前,会直接从缓存获取后返回,如缓存不存在,就进入请求并缓存返回(一般用于查询)
@CachePut:对请求的返回值进行缓存(一般用户更新)
@CacheEvict:清理缓存
@Cacheing:用户以上多个注解的组合,一般不会使用,有兴趣的同学可以查下相关资料

下面简单描述下,@Cacheable里的一些属性,其它注解基本字段一样
@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface Cacheable {
@AliasFor("cacheNames")
String[] value() default {}; // cache别名
@AliasFor("value")
String[] cacheNames() default {}; // cache的key
String key() default ""; // 指定key的生成器,自定义需实现KeyGenerator
String keyGenerator() default ""; // cache管理器,文章使用redis进行存储
String cacheManager() default ""; // cache解析器,管理cache管理器
String cacheResolver() default ""; // 请求时条件判断,如符合则取缓存,若无缓存,则执行代码,返回时进行缓存
String condition() default ""; // 去除符合条件的数据
String unless() default ""; // 是否同步缓存
boolean sync() default false;
}

keyGenerator:key生成器,springcache提供了默认的生成器org.springframework.cache.interceptor.SimpleKeyGenerator,其实无非就是根据注解、方法、参数来生成。当然,我们也可以自定义,只需实现org.springframework.cache.interceptor.KeyGenerator即可

cacheManager:缓存管理器,默认使用ConCurrentHashMap来进行缓存,当然,如果接入redis,则默认使用redis来进行存储,cache已自动集成,如需自定义redis配置,可通过org.springframework.data.redis.cache.RedisCacheManager实现

cacheResolver:缓存解析器,与cacheManager冲突,只需配置一个,有兴趣可自学

condition:请求时判断参数,如符合,则取缓存返回(正则表达式可自行前往官网查看)

unless:返回时判断结果,如符合,则从返回结果中过滤不进行缓存(正则表达式可自行前往官网查看)

sync:并发请求下,只会有一个请求进行缓存处理,其它请求等待

实战

1、添加依赖

        <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2、启动类添加注解@EnableCaching,接入springcache

3、添加redis配置(redis的信息,请自行配置)

    @Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
template.setConnectionFactory(factory); // 指定序列化器
RedisSerializer<?> stringRS = new StringRedisSerializer();
RedisSerializer<?> objectRS = new GenericJackson2JsonRedisSerializer();
template.setKeySerializer(stringRS);
template.setHashKeySerializer(stringRS);
template.setValueSerializer(objectRS);
template.setHashValueSerializer(objectRS); // 初始化redis配置
template.afterPropertiesSet(); return template;
}

4、自定义缓存配置,设置RedisCacheManager

@Configuration
public class CacheConfig extends CachingConfigurerSupport { // 指定cachemanager【因cache默认指定的是RedisTemplate,所以此处进行指定设置】(引入redis时,spring会自动引入redis作为存储)[否则,使用cafficeCache或者其它,比如guavacache]
@Bean
public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
RedisCacheConfiguration cacheConfiguration =
RedisCacheConfiguration.defaultCacheConfig() // 创建默认缓存配置对象
.disableCachingNullValues() // 如果值为空,则不进行缓存
.entryTtl(Duration.ofMinutes(30)) // 设置缓存失效时间
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer()));
return RedisCacheManager.builder(redisConnectionFactory).cacheDefaults(cacheConfiguration).build();
}
}

5、测试

返回String测试

@RestController
@RequestMapping("single")
public class SingleCacheTest { private static final String CACHE_KEY = "single"; protected final Log logger = LogFactory.getLog(this.getClass()); @GetMapping("test")
public String test() throws Exception {
logger.info("single test come in");
return "success";
} @Cacheable(value = CACHE_KEY,sync = true)
@GetMapping("set")
public String set() throws Exception {
logger.info("single set come in");
return "success";
} @CachePut(value = CACHE_KEY)
@GetMapping("put")
public String put() throws Exception {
logger.info("single put come in");
return "success";
} @CacheEvict(CACHE_KEY)
@GetMapping("delete")
public String delete() throws Exception {
logger.info("single delete come in");
return "success";
} }

返回对象测试

@RestController
@RequestMapping("object")
public class ObjectCacheTest { private static final String CACHE_KEY = "object"; protected final Log logger = LogFactory.getLog(this.getClass()); @GetMapping(value = "test")
public People test() throws Exception {
logger.info("object test come in");
return new People("yhc", 30, "武汉");
} @Cacheable(value = CACHE_KEY, condition = "#name.equals('yhc')")
@GetMapping("put1")
public People put1(@RequestParam String name) throws Exception {
logger.info("object put1 come in");
return new People("yhc", 30, "武汉");
} @Cacheable(value = CACHE_KEY, unless = "#result.address.equals('武汉')")
@GetMapping("put2")
public People put2(@RequestParam String name) throws Exception {
logger.info("object put2 come in");
return new People("yhc", 30, "武汉");
} @Cacheable(value = CACHE_KEY, condition = "#name.equals('yhc')", unless = "#result.address.equals('武汉1')")
@GetMapping("put")
public People put(@RequestParam String name) throws Exception {
logger.info("object put come in");
return new People("yhc", 30, "武汉");
} @CacheEvict(CACHE_KEY)
@GetMapping("delete")
public People delete() throws Exception {
logger.info("object delete come in");
return new People("yhc", 30, "武汉");
}
}

springcache+redis实战的更多相关文章

  1. Redis实战阅读笔记——开始

    Redis实战这本书,看完以后最大的不是redis本身的东西,而是作者面对实际问题的分析而给出的设计方案,可以看成NoSql设计的应用.个人从这方面收获很多,至于Redis本身的东西,这个就花一两个小 ...

  2. Redis实战阅读笔记——第一章

    Redis 实战 中文版 的20-21页看的人郁闷死了,最后看英文版才明白意思,哎,我理解能力差成这样了 其中,图 1-12 有错误,草,这个是英文版的错--应该是group:programming

  3. redis实战(01)_redis安装

    早就想对redis进行实战操作了,最近看了一些视频和参考书籍,总结总结一下,redis实战内容: 实战前先对redis做一个大概的认识: 现在开始安装redis了... redis的安装下载地址 ht ...

  4. C# Redis实战(二) [转]

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图               ...

  5. (转)国内外三个不同领域巨头分享的Redis实战经验及使用场景

    随着应用对高性能需求的增加,NoSQL逐渐在各大名企的系统架构中生根发芽.这里我们将为大家分享社交巨头新浪微博.传媒巨头Viacom及图片分享领域佼佼者Pinterest带来的Redis实践,首先我们 ...

  6. C# Redis实战

    转自  :http://blog.csdn.net/qiujialongjjj/article/details/16945569 一.初步准备 Redis 是一个开源的使用ANSI C 语言编写.支持 ...

  7. Redis实战

    大约一年多前,公司同事开始使用Redis,不清楚是配置,还是版本的问题,当时的Redis经常在使用一段时间后,连接爆满且不释放.印象中,Redis 2.4.8以下的版本由于设计上的主从库同步问题,就会 ...

  8. Redis实战之Redis + Jedis

    用Memcached,对于缓存对象大小有要求,单个对象不得大于1MB,且不支持复杂的数据类型,譬如SET 等.基于这些限制,有必要考虑Redis! 相关链接: Redis实战 Redis实战之Redi ...

  9. Redis实战之征服 Redis + Jedis + Spring (一)

    Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)接着需要快速的调研下基于Spring框架下的Redis操作. 相关链接: Redis实战 Re ...

  10. Redis实战之征服 Redis + Jedis + Spring (二)

    不得不说,用哈希操作来存对象,有点自讨苦吃! 不过,既然吃了苦,也做个记录,也许以后API升级后,能好用些呢?! 或许,是我的理解不对,没有真正的理解哈希表. 相关链接: Redis实战 Redis实 ...

随机推荐

  1. Kubernetes 证书详解

    K8S 证书介绍 在 Kube-apiserver 中提供了很多认证方式,其中最常用的就是 TLS 认证,当然也有 BootstrapToken,BasicAuth 认证等,只要有一个认证通过,那么 ...

  2. QQ 邮箱设置自定义域名邮箱

    编者有话说 这篇文章来源于2019年12月左右,我在配置 Galaxy 生信分析平台的邮件服务过程中的一个尝试,我最早把它记录在了语雀上面,但由于某些原因一直迟迟没有更新到生信科技爱好者的公众号.直至 ...

  3. ORM总览

    ORM(Object-Relational Mapping)是一种常见的数据访问技术,它将对象模型和关系模型之间进行映射.ORM的主要作用是简化数据访问和管理,提高开发效率和代码质量.在实际应用中,O ...

  4. CKS 考试题整理 (02)-Apparmor

    Context Apparmor 已在 cluster 的工作节点 node02 上被启用.一个 Apparmor 配置文件已存在,但尚未被实施. Task 在 cluster 的工作节点 node0 ...

  5. 【webpack系列】从基础配置到掌握进阶用法

    前言 本篇文章将介绍一些webpack的进阶用法,演示内容继承自上一篇文章的内容,所以没看过上一篇文章的建议先学习上一篇内容再阅读此篇内容,会更有利于此篇的学习- 文件指纹 文件指纹指的是打包输出的文 ...

  6. 逍遥自在学C语言 | 指针陷阱-空指针与野指针

    前言 在C语言中,指针是一种非常强大和灵活的工具,但同时也容易引发一些问题,其中包括空指针和野指针. 本文将带你了解这两个概念的含义.产生原因以及如何避免它们所导致的问题. 一.人物简介 第一位闪亮登 ...

  7. 精选8道ES高频面试题和答案,后悔没早点看。

    不要再干巴巴的背诵八股文了,一定要结合具体场景回答面试问题! 前言 我们在回答面试题的时候,不能干巴巴的去背八股文,一定要结合应用场景,最好能结合过去做过的项目,去和面试官沟通. 这些场景题虽然不要求 ...

  8. vue2父传子,子传父

    首先看父传子 自定义一个子组件 <template> <div> 子组件: <span>{{inputName}}</span> </div> ...

  9. Java判断一个数是不是质数

    判断一个数是不是质数 做这个题之前我们需要先进行了解什么是质数 质数:只能被1和它本身整除的数 举一个简单的例子:数字5是不是质数呢? 我们可以进行分析: 解题思路:5可以分为1 2 3 4 5,我们 ...

  10. Java 设计模式实战系列—工厂模式

    在 Java 开发中,对象的创建是一个常见的场景,如果对象的创建和使用都写在一起,代码的耦合度高,也不利于后期的维护.我们可以使用工厂模式来解决这个问题,工厂模式是一个创建型模式,将对象的创建和使用分 ...