Spring Cache整合Redis實(shí)現(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 //給緩存取了一個(gè)名字
在啟動(dòng)類(lèi)上添加注解,表示開(kāi)啟緩存
完成了這些配置之后,Spring Boot就會(huì)自動(dòng)幫
@SpringBootApplication @EnableCaching public class RediscacheApplication { public static void main(String[] args) { SpringApplication.run(RediscacheApplication.class, args); } }
我們?cè)诤笈_(tái)配置一個(gè)RedisCacheManager,相關(guān)的配置是在org.springframework.boot.autoconfigure.cache.RedisCacheConfiguration類(lèi)中完成的。部分源碼如下:
@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)會(huì)自動(dòng)提供一個(gè)RedisCacheManger的Bean,RedisCacheManager間接實(shí)現(xiàn)了Spring中的Cache接口,有了這個(gè)Bean,我們就可以直接使用Spring中的緩存注解和接口了,而緩存數(shù)據(jù)則會(huì)被自動(dòng)存儲(chǔ)到Redis上。
在單機(jī)的Redis中,這個(gè)Bean系統(tǒng)會(huì)自動(dòng)提供,如果是Redis集群,這個(gè)Bean需要開(kāi)發(fā)者來(lái)提供
緩存使用@CachaConfig
這個(gè)注解在類(lèi)上使用,用來(lái)描述該類(lèi)中所有方法使用的緩存名稱(chēng),當(dāng)然也可以不使用該注解,直接在具體的緩存注解上配置名稱(chēng),示例代碼如下:
@Service @CacheConfig(cacheNames = "c1") public class UserService { }
@Cacheable
這個(gè)注解一般加載查詢方法上,表示將一個(gè)方法的返回值緩存起來(lái),默認(rèn)情況下,緩存的key就是方法的參數(shù),緩存的value就是方法的返回值,示例代碼如下:
@Cacheable(key = "#id") public User getUserById(Integer id,String username) { System.out.println("getUserById"); return getUserFromDBById(id); }
當(dāng)有多個(gè)參數(shù)時(shí),默認(rèn)就使用多個(gè)參數(shù)來(lái)做key,如果只需要其中某一個(gè)參數(shù)做key,則可以在@Cacheable注解中,通過(guò)key屬性來(lái)指定key,如上代碼就表示只使用id作為緩存的key,如果對(duì)key有復(fù)雜的要求,可以自定義keyGenerator。當(dāng)然,Spring Cache中提供了root對(duì)象,可以在不定義keyGenerator的情況下實(shí)現(xiàn)一些復(fù)雜的效果:
@CachePut
這個(gè)注解一般加在更新方法上,當(dāng)數(shù)據(jù)庫(kù)中的數(shù)據(jù)更新后,緩存中的數(shù)據(jù)也要跟著更新,使用該注解,可以將方法的返回值自動(dòng)更新到已經(jīng)存在的key上,示例代碼如下:
@CachePut(key = "#user.id") public User updateUserById(User user) { return user; }
@CacheEvict
這個(gè)注解一般加在刪除方法上,當(dāng)數(shù)據(jù)庫(kù)中的數(shù)據(jù)刪除后,相關(guān)的緩存數(shù)據(jù)也要自動(dòng)清除,該注解在使用的時(shí)候也可以配置按照某種條件刪除(condition屬性)或者或者配置清除所有緩存(allEntries屬性),示例代碼如下:
@CacheEvict() public void deleteUserById(Integer id) { //在這里執(zhí)行刪除操作, 刪除是去數(shù)據(jù)庫(kù)中刪除 }
總結(jié)
在SpringBoot中,使用Redis緩存,既可以使用RedisTemplate自己來(lái)實(shí)現(xiàn),也可以使用使用這種方式,這種方式是Spring
Cache提供的統(tǒng)一接口,實(shí)現(xiàn)既可以是Redis,也可以是Ehcache或者其他支持這種規(guī)范的緩存框架。從這個(gè)角度來(lái)說(shuō),SpringCache和Redis、Ehcache的關(guān)系就像JDBC與各種數(shù)據(jù)庫(kù)驅(qū)動(dòng)的關(guān)系。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java SpringCache+Redis緩存數(shù)據(jù)詳解
- 詳解SpringBoot2.0的@Cacheable(Redis)緩存失效時(shí)間解決方案
- SpringBoot+SpringCache實(shí)現(xiàn)兩級(jí)緩存(Redis+Caffeine)
- Spring @Cacheable redis異常不影響正常業(yè)務(wù)方案
- SpringCache 分布式緩存的實(shí)現(xiàn)方法(規(guī)避redis解鎖的問(wèn)題)
- Spring cache整合redis代碼實(shí)例
- Spring Cache與Redis結(jié)合的使用方式
相關(guān)文章
java使用apache.poi導(dǎo)出word文件的示例代碼
這篇文章主要介紹了java使用apache.poi導(dǎo)出word文件,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07Maven搭建springboot項(xiàng)目的方法步驟
這篇文章主要介紹了Maven搭建springboot項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04淺析java實(shí)現(xiàn)數(shù)據(jù)加密問(wèn)題
本文通過(guò)實(shí)例代碼給大家介紹了java實(shí)現(xiàn)數(shù)據(jù)加密問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-11-11Spring Cloud微服務(wù)使用webSocket的方法
WebSocket在現(xiàn)代瀏覽器中的應(yīng)用已經(jīng)算是比較普遍了,在某些業(yè)務(wù)場(chǎng)景下,要求必須能夠在服務(wù)器端推送消息至客戶端,本文給大家介紹Spring Cloud微服務(wù)使用webSocket的方法,感興趣的朋友一起看看吧2021-06-06Java實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07JAVA8 List<List<Integer>> list中再裝一個(gè)list轉(zhuǎn)成一個(gè)list操
這篇文章主要介紹了JAVA8 List<List<Integer>> list中再裝一個(gè)list轉(zhuǎn)成一個(gè)list操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08一招教你使用Java執(zhí)行g(shù)roovy腳本的兩種方式
本文主要介紹了一招教你使用Java執(zhí)行g(shù)roovy腳本的兩種方式,一種是通過(guò)腳本引擎ScriptEngine提供的eval(String)方法執(zhí)行腳本內(nèi)容,一種是執(zhí)行g(shù)roovy腳本,感興趣的可以了解一下2023-09-09