摘要:引入依賴庫在中引入依賴庫,如下注解使用自定義應(yīng)用到寫數(shù)據(jù)的方法上,如新增修改方法即應(yīng)用到移除數(shù)據(jù)的方法上,如刪除方法提供的上下文數(shù)據(jù)提供了一些供我們使用的上下文數(shù)據(jù),下表直接摘自官方文檔名字位置描述示例對象當(dāng)前被調(diào)用的方法
引入依賴庫
在pom中引入依賴庫,如下
注解使用org.springframework.boot spring-boot-starter-data-redis redis.clients jedis
@Cacheable @Cacheable("product") @Cacheable(value = {"product","order"}, key = "#root.targetClass+"-"+#id") @Cacheable(value = "product", key = "#root.targetClass+"-"+#id") 自定義cacheManager @Cacheable(value = "product", key = "#root.targetClass+"-"+#id” cacheManager="cacheManager") @CachePut 應(yīng)用到寫數(shù)據(jù)的方法上,如新增/修改方法 @CachePut(value = "product", key = "#root.targetClass+"-"+#product.id") @CacheEvict 即應(yīng)用到移除數(shù)據(jù)的方法上,如刪除方法 @CacheEvict(value = "product", key = "#root.targetClass+"-"+#id") 提供的SpEL上下文數(shù)據(jù)
Spring Cache提供了一些供我們使用的SpEL上下文數(shù)據(jù),下表直接摘自Spring官方文檔:
名字 | 位置 | 描述 | 示例 |
---|---|---|---|
methodName | root對象 | 當(dāng)前被調(diào)用的方法名 | #root.methodName |
method | root對象 | 當(dāng)前被調(diào)用的方法 | #root.method.name |
target | root對象 | 當(dāng)前被調(diào)用的目標(biāo)對象 | #root.target |
targetClass | root對象 | 當(dāng)前被調(diào)用的目標(biāo)對象類 | #root.targetClass |
args | root對象 | 當(dāng)前被調(diào)用的方法的參數(shù)列表 | #root.args[0] |
caches | root對象 | 當(dāng)前方法調(diào)用使用的緩存列表(如@Cacheable(value={"cache1", "cache2"})),則有兩個(gè)cache | #root.caches[0].name |
argument name | 執(zhí)行上下文 | 當(dāng)前被調(diào)用的方法的參數(shù),如findById(Long id),我們可以通過#id拿到參數(shù) | #user.id |
result | 執(zhí)行上下文 | 方法執(zhí)行后的返回值(僅當(dāng)方法執(zhí)行之后的判斷有效,如‘unless’,"cache evict"的beforeInvocation=false) | #result |
@Configuration @EnableCaching public class RedisConfig extends CachingConfigurerSupport { /** * 自定義redis key值生成策略 */ @Bean @Override public KeyGenerator keyGenerator() { return (target, method, params) -> { StringBuilder sb = new StringBuilder(); sb.append(target.getClass().getName()); sb.append(method.getName()); for (Object obj : params) { sb.append(obj.toString()); } return sb.toString(); }; } @Bean public RedisTemplateredisTemplate(RedisConnectionFactory factory) { ObjectMapper om = new ObjectMapper(); om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); //redis序列化 Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class); jackson2JsonRedisSerializer.setObjectMapper(om); StringRedisTemplate template = new StringRedisTemplate(factory); template.setValueSerializer(jackson2JsonRedisSerializer); template.afterPropertiesSet(); return template; } /** * 自定義CacheManager */ @Bean public CacheManager cacheManager(RedisTemplate redisTemplate) { //全局redis緩存過期時(shí)間 RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofDays(1)); RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisTemplate.getConnectionFactory()); return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration); } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/62021.html
摘要:在查詢的服務(wù)方法上添加如下注解表明該方法的返回值需要緩存。當(dāng)被緩存的數(shù)據(jù)發(fā)生改變,緩存需要被清理或者修改,這里使用如下注解清除指定的緩存。事務(wù)是一個(gè)原子操作,所有的緩存,消息,這種非強(qiáng)一致性要求的操作,都應(yīng)該在事務(wù)成功提交后執(zhí)行。 【為什么使用redis 性能極高,redis能讀的速度是110000次/s,寫的速度是81000次/s 豐富的數(shù)據(jù)類型,redis支持二進(jìn)制案例的 Str...
摘要:和注解的方法返回值要一致刪除緩存在需要?jiǎng)h除緩存的方法上加注解,執(zhí)行完這個(gè)方法之后會(huì)將中對應(yīng)的記錄刪除。代表返回值,意思是當(dāng)返回碼不等于時(shí)不緩存,也就是等于時(shí)才緩存。返回值特定值如果被設(shè)置了如果沒有被設(shè)置例子自動(dòng)將對應(yīng)到并且返回原來對應(yīng)的。 本文主要講 Redis 的使用,如何與 SpringBoot 項(xiàng)目整合,如何使用注解方式和 RedisTemplate 方式實(shí)現(xiàn)緩存。最后會(huì)給一個(gè)用...
閱讀 2077·2021-11-24 09:39
閱讀 795·2021-09-30 09:48
閱讀 986·2021-09-22 15:29
閱讀 2421·2019-08-30 14:17
閱讀 1895·2019-08-30 13:50
閱讀 1352·2019-08-30 13:47
閱讀 989·2019-08-30 13:19
閱讀 3428·2019-08-29 16:43