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

Springboot?集成spring?cache緩存的解決方案

 更新時(shí)間:2022年06月02日 08:59:18   作者:字母哥哥  
這篇文章主要介紹了Springboot?集成spring?cache緩存,使用緩存最關(guān)鍵的一點(diǎn)就是保證緩存與數(shù)據(jù)庫(kù)的數(shù)據(jù)一致性,本文給大家介紹最常用的緩存操作模式,對(duì)Springboot?集成spring?cache緩存操作流程感興趣的朋友一起看看吧

一、為什么要做緩存

  • 提升性能

絕大多數(shù)情況下,關(guān)系型數(shù)據(jù)庫(kù)select查詢是出現(xiàn)性能問(wèn)題最大的地方。一方面,select 會(huì)有很多像 join、group、order、like 等這樣豐富的語(yǔ)義,而這些語(yǔ)義是非常耗性能的;另一方面,大多數(shù)應(yīng)用都是讀多寫少,所以加劇了慢查詢的問(wèn)題。

分布式系統(tǒng)中遠(yuǎn)程調(diào)用也會(huì)耗很多性能,因?yàn)橛芯W(wǎng)絡(luò)開銷,會(huì)導(dǎo)致整體的響應(yīng)時(shí)間下降。為了挽救這樣的性能開銷,在業(yè)務(wù)允許的情況(不需要太實(shí)時(shí)的數(shù)據(jù))下,使用緩存是非常必要的事情。

  • 緩解數(shù)據(jù)庫(kù)壓力

當(dāng)用戶請(qǐng)求增多時(shí),數(shù)據(jù)庫(kù)的壓力將大大增加,通過(guò)緩存能夠大大降低數(shù)據(jù)庫(kù)的壓力。

二、常用緩存操作流程

使用緩存最關(guān)鍵的一點(diǎn)就是保證:緩存與數(shù)據(jù)庫(kù)的數(shù)據(jù)一致性,該怎么去做?下圖是一種最常用的緩存操作模式,來(lái)保證數(shù)據(jù)一致性。

  • 更新寫數(shù)據(jù):先把數(shù)據(jù)存到數(shù)據(jù)庫(kù)中,然后再讓緩存失效或更新。緩存操作失敗,數(shù)據(jù)庫(kù)事務(wù)回滾。
  • 刪除寫數(shù)據(jù): 先從數(shù)據(jù)庫(kù)里面刪掉數(shù)據(jù),再?gòu)木彺胬锩鎰h掉。緩存操作失敗,數(shù)據(jù)庫(kù)事務(wù)回滾。
  • 查詢讀數(shù)據(jù)
  • 緩存命中:先去緩存 cache 中取數(shù)據(jù),取到后返回結(jié)果。
  • 緩存失效:應(yīng)用程序先從 cache 取數(shù)據(jù),沒(méi)有得到,則從數(shù)據(jù)庫(kù)中取數(shù)據(jù),成功后,在將數(shù)據(jù)放到緩存中。

如果上面的這些更新、刪除、查詢操作流程全都由程序員通過(guò)編碼來(lái)完成的話

  • 因?yàn)榧尤刖彺鎸?,程序員的編碼量大大增多
  • 緩存層代碼和業(yè)務(wù)代碼耦合,造成難以維護(hù)的問(wèn)題。

三、整合Spring Cache

我們可以使用Spring cache解決上面遇到的兩個(gè)問(wèn)題,Spring cache通過(guò)注解的方式來(lái)操作緩存,一定程度上減少了程序員緩存操作代碼編寫量。注解添加和移除都很方便,不與業(yè)務(wù)代碼耦合,容易維護(hù)。
第一步:pom.xml 添加 Spring Boot 的 jar 依賴:

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

第二步:添加入口啟動(dòng)類 @EnableCaching 注解開啟 Caching,實(shí)例如下。

@EnableCaching

在Spring Boot中通過(guò)@EnableCaching注解自動(dòng)化配置合適的緩存管理器(CacheManager),Spring Boot根據(jù)下面的順序去偵測(cè)緩存提供者,也就是說(shuō)Spring Cache支持下面的這些緩存框架:

  • Generic
  • JCache (JSR-107) (EhCache 3, Hazelcast, Infinispan, and others)
  • EhCache 2.x
  • Hazelcast
  • Infinispan
  • Couchbase
  • Redis(因?yàn)槲覀冎耙肓薘edis,所以使用redis作為緩存)
  • Caffeine
  • Simple

四、在ArticleController類上實(shí)現(xiàn)一個(gè)簡(jiǎn)單的例子

下面的例子第一次訪問(wèn)走數(shù)據(jù)庫(kù)(代碼上斷點(diǎn)斷下來(lái)),第二次訪問(wèn)就走緩存了(不走函數(shù)代碼)。可以自己下斷點(diǎn)試一下。

@Cacheable(value="article")
@GetMapping( "/article/{id}")
public @ResponseBody  AjaxResponse getArticle(@PathVariable Long id) {

使用redis緩存,被緩存的對(duì)象(函數(shù)返回值)有幾個(gè)非常需要注意的點(diǎn):

  • 必須實(shí)現(xiàn)無(wú)參的構(gòu)造函數(shù)
  • 需要實(shí)現(xiàn)Serializable 接口和定義serialVersionUID (因?yàn)榫彺嫘枰褂肑DK的方式序列化和反序列化)。

本專欄后續(xù)文章中會(huì)給出更加詳細(xì)的例子說(shuō)明。

五、更改Redis緩存的序列化方式

讓緩存使用JDK默認(rèn)的序列化和反序列化方式非常不友好,我們完全可以修改為使用JSON序列化與反序列化的方式,可讀性更強(qiáng),體積更小,速度更快。

@Configuration
public class RedisConfig {
   //這個(gè)函數(shù)是上一節(jié)的內(nèi)容
   @Bean
   public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
       RedisTemplate redisTemplate = new RedisTemplate();
       redisTemplate.setConnectionFactory(redisConnectionFactory);
       Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

       ObjectMapper objectMapper = new ObjectMapper();
       objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
       objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

       jackson2JsonRedisSerializer.setObjectMapper(objectMapper);

       //重點(diǎn)在這四行代碼
       redisTemplate.setKeySerializer(new StringRedisSerializer());
       redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
       redisTemplate.setHashKeySerializer(new StringRedisSerializer());
       redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);

       redisTemplate.afterPropertiesSet();
       return redisTemplate;
   }

    //本節(jié)的重點(diǎn)配置,讓Redis緩存的序列化方式使用redisTemplate.getValueSerializer()
   //不在使用JDK默認(rèn)的序列化方式
   @Bean
   public RedisCacheManager redisCacheManager(RedisTemplate redisTemplate) {
       RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisTemplate.getConnectionFactory());
       RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
               .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(redisTemplate.getValueSerializer()));
       return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);
   }
}

到此這篇關(guān)于Springboot 集成spring cache緩存的文章就介紹到這了,更多相關(guān)Springboot 集成spring cache緩存內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中為什么ArrayList初始化容量大小為10

    Java中為什么ArrayList初始化容量大小為10

    這篇文章主要介紹了Java中為什么ArrayList初始化容量大小為10,帶著問(wèn)題圍展開詳細(xì)的介紹,感興趣的小伙伴可以參考一下
    2022-06-06
  • 解決mybatis resultMap根據(jù)type找不到對(duì)應(yīng)的包問(wèn)題

    解決mybatis resultMap根據(jù)type找不到對(duì)應(yīng)的包問(wèn)題

    這篇文章主要介紹了解決mybatis resultMap根據(jù)type找不到對(duì)應(yīng)的包問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Mybatis中#{}和${}傳參的區(qū)別及#和$的區(qū)別小結(jié)

    Mybatis中#{}和${}傳參的區(qū)別及#和$的區(qū)別小結(jié)

    這篇文章主要介紹了Mybatis中#{}和${}傳參的區(qū)別及#和$的區(qū)別小結(jié) 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • Mybatis集成到Spring容器的詳細(xì)步驟

    Mybatis集成到Spring容器的詳細(xì)步驟

    在現(xiàn)在的JavaEE開發(fā)過(guò)程中,我們經(jīng)常會(huì)使用到Spring+SpringMVC+Mybatis這個(gè)組合,那么Mybatis是如何集成到Spring中的呢,下面通過(guò)實(shí)例代碼給大家詳細(xì)講解,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Springboot使用kafka的兩種方式

    Springboot使用kafka的兩種方式

    在公司用kafka比較多,今天整理下Springboot使用kafka的兩種方式,Kafka作為一個(gè)消息發(fā)布訂閱系統(tǒng),就包括消息生成者和消息消費(fèi)者,文中通過(guò)代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-11-11
  • idea編譯報(bào)錯(cuò)-代碼沒(méi)問(wèn)題IDEA編譯不通過(guò)的處理方案

    idea編譯報(bào)錯(cuò)-代碼沒(méi)問(wèn)題IDEA編譯不通過(guò)的處理方案

    這篇文章主要介紹了idea編譯報(bào)錯(cuò)-代碼沒(méi)問(wèn)題IDEA編譯不通過(guò)的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 一次java異步任務(wù)的實(shí)戰(zhàn)記錄

    一次java異步任務(wù)的實(shí)戰(zhàn)記錄

    最近做項(xiàng)目的時(shí)候遇到了一個(gè)小問(wèn)題,從前臺(tái)提交到服務(wù)端A,A調(diào)用服務(wù)端B處理超時(shí),下面這篇文章主要給大家介紹了一次java異步任務(wù)的實(shí)戰(zhàn)記錄,需要的朋友可以參考下
    2022-05-05
  • Java非靜態(tài)成員變量之死循環(huán)(詳解)

    Java非靜態(tài)成員變量之死循環(huán)(詳解)

    下面小編就為大家?guī)?lái)一篇Java非靜態(tài)成員變量之死循環(huán)(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 如何把第三方服務(wù)注冊(cè)到spring項(xiàng)目容器中

    如何把第三方服務(wù)注冊(cè)到spring項(xiàng)目容器中

    這篇文章主要為大家介紹了如何把第三方服務(wù)注冊(cè)到spring項(xiàng)目容器中,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Spring超詳細(xì)講解BeanUtils改造

    Spring超詳細(xì)講解BeanUtils改造

    BeanUtils.copyProperties();確實(shí)為我們做了很多事情,雖然不能完美完成深拷貝,但是對(duì)于?po、vo、dto?的拷貝已經(jīng)足夠用了。但是其還是有一些不夠完美的地方,下面我們來(lái)探討一下有哪些不足以及改造
    2022-06-06

最新評(píng)論