Spring Cache整合Redis實現(xiàn)方法詳解
導(dǎo)入依賴
<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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
基本配置
spring.redis.port=6380
spring.redis.host=192.168.66.128spring.cache.cache-names=c1 //給緩存取了一個名字
在啟動類上添加注解,表示開啟緩存
完成了這些配置之后,Spring Boot就會自動幫
@SpringBootApplication
@EnableCaching
public class RediscacheApplication {
public static void main(String[] args) {
SpringApplication.run(RediscacheApplication.class, args);
}
}
我們在后臺配置一個RedisCacheManager,相關(guān)的配置是在org.springframework.boot.autoconfigure.cache.RedisCacheConfiguration類中完成的。部分源碼如下:
@Configuration
@ConditionalOnClass(RedisConnectionFactory.class)
@AutoConfigureAfter(RedisAutoConfiguration.class)
@ConditionalOnBean(RedisConnectionFactory.class)
@ConditionalOnMissingBean(CacheManager.class)
@Conditional(CacheCondition.class)
class RedisCacheConfiguration {
@Bean
public RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory,
ResourceLoader resourceLoader) {
RedisCacheManagerBuilder builder = RedisCacheManager
.builder(redisConnectionFactory)
.cacheDefaults(determineConfiguration(resourceLoader.getClassLoader()));
List<String> cacheNames = this.cacheProperties.getCacheNames();
if (!cacheNames.isEmpty()) {
builder.initialCacheNames(new LinkedHashSet<>(cacheNames));
}
return this.customizerInvoker.customize(builder.build());
}
}
系統(tǒng)會自動提供一個RedisCacheManger的Bean,RedisCacheManager間接實現(xiàn)了Spring中的Cache接口,有了這個Bean,我們就可以直接使用Spring中的緩存注解和接口了,而緩存數(shù)據(jù)則會被自動存儲到Redis上。
在單機的Redis中,這個Bean系統(tǒng)會自動提供,如果是Redis集群,這個Bean需要開發(fā)者來提供
緩存使用@CachaConfig
這個注解在類上使用,用來描述該類中所有方法使用的緩存名稱,當(dāng)然也可以不使用該注解,直接在具體的緩存注解上配置名稱,示例代碼如下:
@Service
@CacheConfig(cacheNames = "c1")
public class UserService {
}
@Cacheable
這個注解一般加載查詢方法上,表示將一個方法的返回值緩存起來,默認(rèn)情況下,緩存的key就是方法的參數(shù),緩存的value就是方法的返回值,示例代碼如下:
@Cacheable(key = "#id")
public User getUserById(Integer id,String username) {
System.out.println("getUserById");
return getUserFromDBById(id);
}
當(dāng)有多個參數(shù)時,默認(rèn)就使用多個參數(shù)來做key,如果只需要其中某一個參數(shù)做key,則可以在@Cacheable注解中,通過key屬性來指定key,如上代碼就表示只使用id作為緩存的key,如果對key有復(fù)雜的要求,可以自定義keyGenerator。當(dāng)然,Spring Cache中提供了root對象,可以在不定義keyGenerator的情況下實現(xiàn)一些復(fù)雜的效果:

@CachePut
這個注解一般加在更新方法上,當(dāng)數(shù)據(jù)庫中的數(shù)據(jù)更新后,緩存中的數(shù)據(jù)也要跟著更新,使用該注解,可以將方法的返回值自動更新到已經(jīng)存在的key上,示例代碼如下:
@CachePut(key = "#user.id")
public User updateUserById(User user) {
return user;
}
@CacheEvict
這個注解一般加在刪除方法上,當(dāng)數(shù)據(jù)庫中的數(shù)據(jù)刪除后,相關(guān)的緩存數(shù)據(jù)也要自動清除,該注解在使用的時候也可以配置按照某種條件刪除(condition屬性)或者或者配置清除所有緩存(allEntries屬性),示例代碼如下:
@CacheEvict()
public void deleteUserById(Integer id) {
//在這里執(zhí)行刪除操作, 刪除是去數(shù)據(jù)庫中刪除
}
總結(jié)
在SpringBoot中,使用Redis緩存,既可以使用RedisTemplate自己來實現(xiàn),也可以使用使用這種方式,這種方式是Spring
Cache提供的統(tǒng)一接口,實現(xiàn)既可以是Redis,也可以是Ehcache或者其他支持這種規(guī)范的緩存框架。從這個角度來說,SpringCache和Redis、Ehcache的關(guān)系就像JDBC與各種數(shù)據(jù)庫驅(qū)動的關(guān)系。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java基于正則表達式實現(xiàn)查找匹配的文本功能【經(jīng)典實例】
這篇文章主要介紹了Java基于正則表達式實現(xiàn)查找匹配的文本功能,結(jié)合具體實例形式分析了java正則查找、字符串遍歷、group分組相關(guān)操作技巧,需要的朋友可以參考下2017-04-04
解決JavaEE開發(fā)中字符編碼出現(xiàn)亂碼的問題
下面小編就為大家?guī)硪黄鉀QJavaEE開發(fā)中字符編碼出現(xiàn)亂碼的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
深入理解Java基礎(chǔ)之try-with-resource語法糖
這篇文章主要介紹了深入理解Java基礎(chǔ)之try-with-resource語法糖,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02
Java的Swing編程中使用SwingWorker線程模式及頂層容器
這篇文章主要介紹了在Java的Swing編程中使用SwingWorker線程模式及頂層容器的方法,適用于客戶端圖形化界面軟件的開發(fā),需要的朋友可以參考下2016-01-01
基于Mybatis Plus實現(xiàn)多表分頁查詢的示例代碼
這篇文章主要介紹了基于Mybatis Plus實現(xiàn)多表分頁查詢的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
SpringIntegration消息路由之Router的條件路由與過濾功能
本文詳細介紹了Router的基礎(chǔ)概念、條件路由實現(xiàn)、基于消息頭的路由、動態(tài)路由與路由表、消息過濾與選擇性路由以及錯誤處理與路由等方面的內(nèi)容,提高了系統(tǒng)的可維護性和可擴展性,感興趣的朋友一起看看吧2025-04-04

