redis的Cacheable注解使用及說明
更新時間:2025年11月07日 11:05:47 作者:我曾遇到一束光
文章介紹了如何在Java應(yīng)用中使用Spring的@Cacheable注解進(jìn)行緩存配置,包括注解的使用、key的生成方式、觸發(fā)條件(condition)和排除條件(unless)的設(shè)置,并強調(diào)了緩存的持久性和清除機制
引入依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.1.1.RELEASE</version>
</dependency>
導(dǎo)入的使用較多的2.1.1依賴,版本過高可能會導(dǎo)致找不到加載類.
添加注解
主類中中加入注解@EnableCaching,
然后就可以在方法或者類上邊使用@Cacheable
- @Cacheable 的作用 主要針對方法配置,能夠根據(jù)方法的請求參數(shù)對其結(jié)果進(jìn)行緩存
- @Cacheable 作用和配置方法
value
- 用來存放我們要保存的key的集合。類型為標(biāo)準(zhǔn)的String
key
- 我們實際要保存到redis的key,可以增加參數(shù),以方法的參數(shù)或者屬性。類型為String,但是需要做處理。 需要將我們自定義的字符串以"’"括起來再與參數(shù)進(jìn)行拼接。
- 如果需要用到方法中的參數(shù),可以用 #+參數(shù)名直接獲 取。
- 如果需要用到方法中參數(shù)的屬性,可以向Java對象一樣,用 . 獲取。如 #channel.name,如果此注解使用在方法上,可以根據(jù)方法設(shè)置key,如:#root.method。

keyGenerator
@Component("myKeyGenerator")
public class MyKeyGenerator implements KeyGenerator {
@Override
public Object generate(Object target, Method method, Object... params) {
return "method.getName()" + "["+ Arrays.asList(params).toString()+"]";
}
}
@Cacheable(value ="provinceCount",keyGenerator = "myKeyGenerator",sync = true)
condition
- 觸發(fā)條件。
- 這個參數(shù)是規(guī)定這個緩存觸發(fā)的條件拼接。
- 如 condition="#channel != null",就是在channel不 為null的時候觸發(fā)。
unless
- 排除條件。
- 這個參數(shù)是規(guī)定這個緩存在什么時候不觸發(fā)。
- 如 unless="#result == null",就是在結(jié)果為null的 時候觸發(fā)。
注意點
使用@Cacheable生成的緩存是不會清除的,同時當(dāng)redis中已經(jīng)存在相同的key時,@Cacheable默認(rèn)不生成緩存
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表
這篇文章主要介紹了Redis數(shù)據(jù)結(jié)構(gòu)中的跳躍表的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
利用redis實現(xiàn)分布式鎖,快速解決高并發(fā)時的線程安全問題
這篇文章主要介紹了利用redis實現(xiàn)分布式鎖,快速解決高并發(fā)時的線程安全問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

