欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Spring Boot中Redis緩存還能這么用

 更新時(shí)間:2019年06月03日 09:43:11   作者:江南一點(diǎn)雨  
這篇文章主要介紹了淺談Spring Boot中Redis緩存還能這么用,這種方式是Spring Cache提供的統(tǒng)一接口,實(shí)現(xiàn)既可以是Redis,也可以是Ehcache或者其他支持這種規(guī)范的緩存框架,感興趣的小伙伴們可以參考一下

經(jīng)過Spring Boot的整合封裝與自動(dòng)化配置,在Spring Boot中整合Redis已經(jīng)變得非常容易了,開發(fā)者只需要引入Spring Data Redis依賴,然后簡(jiǎn)單配下redis的基本信息,系統(tǒng)就會(huì)提供一個(gè)RedisTemplate供開發(fā)者使用,但是今天松哥想和大伙聊的不是這種用法,而是結(jié)合Cache的用法。Spring3.1中開始引入了令人激動(dòng)的Cache,在Spring Boot中,可以非常方便的使用Redis來作為Cache的實(shí)現(xiàn),進(jìn)而實(shí)現(xiàn)數(shù)據(jù)的緩存。

工程創(chuàng)建

首先創(chuàng)建一個(gè)Spring Boot工程,注意創(chuàng)建的時(shí)候需要引入三個(gè)依賴,web、cache以及redis,如下圖:

對(duì)應(yīng)的依賴內(nèi)容如下:

<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> 

基本配置

工程創(chuàng)建好之后,首先需要簡(jiǎn)單配置一下Redis,Redis的基本信息,另外,這里要用到Cache,因此還需要稍微配置一下Cache,如下:

spring.redis.port=6380 
spring.redis.host=192.168.66.128 
 
spring.cache.cache-names=c1 

簡(jiǎn)單起見,這里我只是配置了Redis的端口和地址,然后給緩存取了一個(gè)名字,這個(gè)名字在后文會(huì)用到。

另外,還需要在配置類上添加如下代碼,表示開啟緩存:

@SpringBootApplication 
@EnableCaching 
public class RediscacheApplication { 
 
public static void main(String[] args) { 
SpringApplication.run(RediscacheApplication.class, args); 
} 
 
} 

完成了這些配置之后,Spring Boot就會(huì)自動(dòng)幫我們?cè)诤笈_(tái)配置一個(gè)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()); 
} 
} 

看類上的注解,發(fā)現(xiàn)在萬事俱備的情況下,系統(tǒng)會(huì)自動(dòng)提供一個(gè)RedisCacheManager的Bean,這個(gè)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需要開發(fā)者來提供(后面的文章會(huì)講到)。

緩存使用

這里主要向小伙伴們介紹緩存中幾個(gè)核心的注解使用。

@CacheConfig

這個(gè)注解在類上使用,用來描述該類中所有方法使用的緩存名稱,當(dāng)然也可以不使用該注解,直接在具體的緩存注解上配置名稱,示例代碼如下:

@Service 
@CacheConfig(cacheNames = "c1") 
public class UserService { 
} 

@Cacheable

這個(gè)注解一般加在查詢方法上,表示將一個(gè)方法的返回值緩存起來,默認(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ù)來做key,如果只需要其中某一個(gè)參數(shù)做key,則可以在@Cacheable注解中,通過key屬性來指定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é)

在Spring Boot中,使用Redis緩存,既可以使用RedisTemplate自己來實(shí)現(xiàn),也可以使用使用這種方式,這種方式是Spring Cache提供的統(tǒng)一接口,實(shí)現(xiàn)既可以是Redis,也可以是Ehcache或者其他支持這種規(guī)范的緩存框架。從這個(gè)角度來說,Spring Cache和Redis、Ehcache的關(guān)系就像JDBC與各種數(shù)據(jù)庫(kù)驅(qū)動(dòng)的關(guān)系。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java虛擬機(jī)底層原理詳細(xì)分析

    Java虛擬機(jī)底層原理詳細(xì)分析

    這篇文章主要介紹了Java虛擬機(jī)底層原理詳細(xì)分析,運(yùn)行時(shí)數(shù)據(jù)區(qū)就是俗稱的虛擬機(jī)內(nèi)存,主要包括我們熟悉的堆、棧、本地方法棧、方法區(qū)(元空間)、程序計(jì)數(shù)器,虛擬機(jī)調(diào)優(yōu)主要針對(duì)的是運(yùn)行時(shí)數(shù)據(jù)區(qū),也就是虛擬機(jī)內(nèi)存,需要的朋友可以參考下
    2024-01-01
  • java 最新Xss攻擊與防護(hù)(全方位360°詳解)

    java 最新Xss攻擊與防護(hù)(全方位360°詳解)

    這篇文章主要介紹了java 最新Xss攻擊與防護(hù)(全方位360°詳解),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • springcloud中Ribbon和RestTemplate實(shí)現(xiàn)服務(wù)調(diào)用與負(fù)載均衡

    springcloud中Ribbon和RestTemplate實(shí)現(xiàn)服務(wù)調(diào)用與負(fù)載均衡

    這篇文章主要介紹了Ribbon和RestTemplate實(shí)現(xiàn)服務(wù)調(diào)用與負(fù)載均衡,想了解負(fù)載均衡的同學(xué)可以參考下
    2021-04-04
  • java?安全ysoserial?URLDNS利用鏈分析

    java?安全ysoserial?URLDNS利用鏈分析

    這篇文章主要為大家介紹了java?安全ysoserial?URLDNS利用鏈分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • SpringCloud Ribbon負(fù)載均衡代碼實(shí)例

    SpringCloud Ribbon負(fù)載均衡代碼實(shí)例

    這篇文章主要介紹了SpringCloud Ribbon負(fù)載均衡代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • java線程池合理設(shè)置最大線程數(shù)和核心線程數(shù)方式

    java線程池合理設(shè)置最大線程數(shù)和核心線程數(shù)方式

    這篇文章主要介紹了java線程池合理設(shè)置最大線程數(shù)和核心線程數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 聊聊spring @Transactional 事務(wù)無法使用的可能原因

    聊聊spring @Transactional 事務(wù)無法使用的可能原因

    這篇文章主要介紹了spring @Transactional 事務(wù)無法使用的可能原因,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 使用mybatis報(bào)Invalid bound statement解決分析

    使用mybatis報(bào)Invalid bound statement解決分析

    這篇文章主要為大家介紹了使用mybatis報(bào)Invalid bound statement原因解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • java獲取和設(shè)置系統(tǒng)變量問題(環(huán)境變量)

    java獲取和設(shè)置系統(tǒng)變量問題(環(huán)境變量)

    這篇文章主要介紹了java獲取和設(shè)置系統(tǒng)變量問題(環(huán)境變量),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序功能的實(shí)現(xiàn)

    Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序功能的實(shí)現(xiàn)

    這篇文章主要介紹了Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序功能的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01

最新評(píng)論