SpringBoot 開啟Redis緩存及使用方法
之前不是說過Redis可以當作緩存用嘛現(xiàn)在我們就配置一下SpringBoot使用Redis的緩存
Redis緩存為什么用Redis作緩存用redis做緩存,是因為redis有著很優(yōu)秀的讀寫能力,在集群下可以保證數(shù)據(jù)的高可用
主要步驟1、pom.xml文件添加依賴
2、yml文件配置redis集群
3、編寫RedisConfig配置序列化及緩存配置,添加緩存注解
4、編寫業(yè)務Controller,添加緩存注解
5、編寫啟動類
具體實踐整體目錄結(jié)構(gòu)pom.xml添加依賴
<?xml version='1.0' encoding='UTF-8'?><project xmlns='http://maven.apache.org/POM/4.0.0' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd'> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>SpringBoot_Redis</artifactId> <version>1.0-SNAPSHOT</version> <properties><java.version>1.8</java.version> </properties> <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.8.RELEASE</version> </parent> <dependencies><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!--整合redis--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId></dependency><!--spring boot test--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId></dependency> </dependencies></project>
結(jié)構(gòu)是ip+port
spring: redis: cluster: nodes:- 169.254.0.100:8001- 169.254.0.100:8002- 169.254.0.100:8003- 169.254.0.100:8004- 169.254.0.100:8005- 169.254.0.100:8006
編寫RedisConfig配置序列化及緩存配置,添加緩存注解
設置緩存的Bean
這里有必要解釋一下
cacheNames.add() 這里我理解的是和controller進行綁定,畢竟很多controller的時候,這里可以確定到底那個controller開啟緩存,以及每個controller對緩存的要求可能也不一樣 configMap這里就是將我們對緩存的一些配置和命名空間進行關聯(lián) 設置緩存時間和禁止緩存空數(shù)據(jù)應該還好理解編寫業(yè)務Controller@RestController@RequestMapping('user')public class RedisCacheController { @Cacheable(value = 'user',key = '#root.methodName+#root.args[0]') @GetMapping('findWord/{id}') public String findWord(@PathVariable String id) {System.out.println('Cacheing');HashMap<String, String> words = new HashMap<>();words.put('1', 'java');words.put('2', 'redis');words.put('3', 'cache');return words.get(id); }}
@Cacheable一定要加在方法之上value就是之前在RedisConfig中定義的命名空間,也是緩存保存的空間key就是緩存保存的key,這里以方法名為key,但是為避免方法名重復導致的key重復,所以加入id,來避免重復
關于緩存的其他注解 @CachePut在支持Spring Cache的環(huán)境中,對于使用@Cacheale標注的方法,Spring在每次執(zhí)行前都會檢查Cache中是否存在相同的key的緩存元素,如果存在就不再執(zhí)行該方法,而是從緩存中獲取結(jié)果直接進行返回,若不存在才會執(zhí)行方法并將返回結(jié)果存入指定的緩存中
@Cacheput也可以生命一個方法支持緩存功能,與@Cacheable不同的是使用@CachePut標注的方法在執(zhí)行并不會去檢查緩存中是否存在之前執(zhí)行過的結(jié)果,而是每次都會執(zhí)行該方法,并將執(zhí)行結(jié)果以鍵值對的形式存入緩存中。
@CacheEvictCacheEvict是用來標注在需要清除緩存元素的方法或類上的。當標記在一個類上時表示其中所有的方法的執(zhí)行都會觸發(fā)緩存的清除操作@CacheEvict可以指定的屬性有value、key、condition、allEntries和beforeInvocation。其中value、key和condition的語義與@Cacheable對應的屬性類似。即value表示清除操作是發(fā)生在哪些緩存(命名空間)上的key表示要清除的是哪個key,如未指定則會誰用默認策略生成的key,condition表示清除操作發(fā)生的條件allEntries屬性allEntries是boolean類型的,表示是否要清除緩存中的所有元素,默認為false,當指定為true時,會忽略指定的keybeforeInvocation屬性清除操作默認時在對應方法成功執(zhí)行后觸發(fā)的,即方法如果因為拋出異常而未能成功返回也不會觸發(fā)清除操作使用beforeInvocation可以改變觸發(fā)清除操作的時間,當我們指定屬性值為true時,Spring會在調(diào)用該方法之前清除緩存中的指定元素 編寫啟動類
就是傳統(tǒng)的啟動類
使用postman發(fā)送請求進行檢測第一次的時候可以看到控制臺打印
這說明方法執(zhí)行了但是第二次發(fā)送相同請求的時候,可以看到拿到了數(shù)據(jù),但是方法沒有執(zhí)行,說明緩存有用了
好了,到此結(jié)束。
到此這篇關于SpringBoot 開啟Redis緩存的文章就介紹到這了,更多相關SpringBoot Redis緩存內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!
相關文章:
1. 使用Python和百度語音識別生成視頻字幕的實現(xiàn)2. Gitlab CI-CD自動化部署SpringBoot項目的方法步驟3. 基于javascript處理二進制圖片流過程詳解4. ajax請求添加自定義header參數(shù)代碼5. JAVA上加密算法的實現(xiàn)用例6. 詳談ajax返回數(shù)據(jù)成功 卻進入error的方法7. axios和ajax的區(qū)別點總結(jié)8. ASP刪除img標簽的style屬性只保留src的正則函數(shù)9. ASP中解決“對象關閉時,不允許操作?!钡脑幃悊栴}……10. Java Lock接口實現(xiàn)原理及實例解析
