您好,登錄后才能下訂單哦!
這篇文章主要講解了“SpringBoot集成SpringCache的過程詳解”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“SpringBoot集成SpringCache的過程詳解”吧!
一、關于Spring Cache
緩存在現在的應用中越來越重要,
Spring從3.1開始定義了org.springframework.cache.Cache和org.springframework.cache.CacheManager接口來統一不同的緩存技術,并支持使用JCache(JSR-107)注解簡化我們開發。
通過SpringCache,可以快速嵌入自己的Cache實現,主要是@Cacheable、@CachePut、@CacheEvict、@CacheConfig、@Caching等注解來實現。
@Cacheable:作用于方法上,用于對于方法返回結果進行緩存,如果已經存在該緩存,則直接從緩存中獲取,緩存的key可以從入參中指定,緩存的value為方法返回值。 @CachePut:作用于方法上,無論是否存在該緩存,每次都會重新添加緩存,緩存的key可以從入參中指定,緩存的value為方法返回值,常用作于更新。 @CacheEvict:作用于方法上,用于清除緩存。 @CacheConfig:作用在類上,統一配置本類的緩存注解的屬性。 @Caching:作用于方法上,用于一次性設置多個緩存。 @EnableCaching:作用于類上,用于開啟注解功能。
二、演示示例
欲使用Spring Cache,需要先引入Spring Cache的依賴。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!--Spring Cache依賴--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId></dependency>
然后在啟動類上,我們需要使用@EnableCaching來聲明開啟緩存。
@EnableCaching //開啟緩存@SpringBootApplicationpublic class SpringbootApplication { public static void main(String[] args) { SpringApplication.run(SpringbootApplication.class, args); }}
這樣就可以使用注解來操作緩存了,創建CacheService類,其中dataMap的Map存儲數據,省去了數據庫的操作。
@Slf4j@Servicepublic class CacheService { private Map<Integer, User> dataMap = new HashMap <Integer, User>(){ { for (int i = 1; i < 100 ; i++) { User u = new User("code" + i, "name" + i); put(i, u); } } }; // 獲取數據 @Cacheable(value = "cache", key = "'user:' + #id") public User get(int id){ log.info("通過id{}查詢獲取", id); return dataMap.get(id); } // 更新數據 @CachePut(value = "cache", key = "'user:' + #id") public User set(int id, User u){ log.info("更新id{}數據", id); dataMap.put(id, u); return u; } //刪除數據 @CacheEvict(value = "cache", key = "'user:' + #id") public User del(int id){ log.info("刪除id{}數據", id); dataMap.remove(id); return u; }}
get方法模擬查詢,@Cacheable用于添加緩存,set方法用于修改,@CachePut更新緩存,del方法用于刪除數據, @CacheEvict刪除緩存。需要注意的是,注解的value表示緩存分類,并不是指緩存的對象值。
然后在創建CacheApi,用于調用CacheService進行測試。
@RestController@RequestMapping("cache")public class CacheApi { @Autowired private CacheService cacheService; @GetMapping("get") public User get(@RequestParam int id){ return cacheService.get(id); } @PostMapping("set") public User set(@RequestParam int id, @RequestParam String code, @RequestParam String name){ User u = new User(code, name); return cacheService.set(id, u); } @DeleteMapping("del") public void del(@RequestParam int id){ cacheService.del(id); }}
然后我們打開swagger-ui界面(http://localhost:10900/swagger-ui.html)進行測試,多次調用查詢,可以看到, CacheService的get方法,對于同一id僅僅執行一遍。然后再調用更新,再次get時,即可發現數據已經更新,而調用del,則可以清除緩存,再次查詢又會調用方法。
源碼地址:https://github.com/imyanger/springboot-project/tree/master/p20-springboot-cache
感謝各位的閱讀,以上就是“SpringBoot集成SpringCache的過程詳解”的內容了,經過本文的學習后,相信大家對SpringBoot集成SpringCache的過程詳解這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。