springboot使用GuavaCache做簡(jiǎn)單緩存處理的方法
問(wèn)題背景
實(shí)際項(xiàng)目碰到一個(gè)上游服務(wù)商接口有10秒的查詢(xún)限制(同個(gè)賬號(hào))。
項(xiàng)目中有一個(gè)需求是要實(shí)時(shí)統(tǒng)計(jì)一些數(shù)據(jù),一個(gè)應(yīng)用下可能有多個(gè)相同的賬號(hào)。由于服務(wù)商接口的限制,當(dāng)批量查詢(xún)時(shí),可能出現(xiàn)同一個(gè)賬號(hào)第一次查詢(xún)有數(shù)據(jù),但第二次查詢(xún)無(wú)數(shù)據(jù)的情況。
解決方案
基于以上問(wèn)題,提出用緩存的過(guò)期時(shí)間來(lái)解決。
這時(shí),可用Redis和Guava Cache來(lái)解決:
當(dāng)批量查詢(xún)時(shí),同一個(gè)賬號(hào)第一次查詢(xún)有數(shù)據(jù)則緩存并設(shè)置過(guò)期時(shí)間10s, 后續(xù)查詢(xún)時(shí)直接從緩存中取,沒(méi)有再?gòu)姆?wù)商查詢(xún)。
最終采用Guava Cache來(lái)解決,原因是:
- 應(yīng)用是部署單臺(tái)的,不會(huì)有分布式的問(wèn)題
- Redis雖然可以實(shí)現(xiàn),但會(huì)有通訊時(shí)間消耗
- Guava Cache使用本地緩存,支持并發(fā)
使用GuavaCache可以快速建立緩存
1.需要在啟動(dòng)類(lèi)上注解@EnableCaching
2.配置CacheManager
3.控制器上注解使用@Cacheable
pom.xml
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>18.0</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build>
CacheConfig.java 配置類(lèi)
package application.config; import com.google.common.cache.CacheBuilder; import org.springframework.cache.CacheManager; import org.springframework.cache.guava.GuavaCache; import org.springframework.cache.support.SimpleCacheManager; import org.springframework.context.annotation.Configuration; import java.util.ArrayList; import java.util.List; import java.util.concurrent.TimeUnit; @Configuration public class CacheConfig { public CacheManager cacheManager(){ GuavaCache guavaCache = new GuavaCache("GuavaCacheAll", CacheBuilder.newBuilder() .recordStats() .expireAfterWrite(10000, TimeUnit.SECONDS) .build()); List list = new ArrayList(); list.add(guavaCache); SimpleCacheManager simpleCacheManager = new SimpleCacheManager(); simpleCacheManager.setCaches(list); return simpleCacheManager; } }
TestController.java 控制器測(cè)試類(lèi)
package application.controller; import org.springframework.cache.annotation.Cacheable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class TestController { @RequestMapping("/test") //key是使用spEl取得參數(shù),根據(jù)參數(shù)name作為緩存的key,value是使用的緩存list中的那個(gè),具體看配置類(lèi) @Cacheable(value = "GuavaCacheAll",key = "#name") public String tt(String name){ System.out.println("in tt"); return "name:"+name; } }
Application.java springboot啟動(dòng)類(lèi)
package application; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCaching; @SpringBootApplication @EnableCaching public class Application { public static void main(String[] args) { SpringApplication.run(Application.class,args); } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于java中byte數(shù)組與int類(lèi)型的轉(zhuǎn)換(兩種方法)
下面小編就為大家?guī)?lái)一篇基于java中byte數(shù)組與int類(lèi)型的轉(zhuǎn)換(兩種方法)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08一文帶你學(xué)習(xí)Java多維數(shù)組的使用技巧
Java作為一門(mén)廣泛應(yīng)用于各行各業(yè)的開(kāi)發(fā)語(yǔ)言,具有豐富的數(shù)據(jù)類(lèi)型支持,其中多維數(shù)組是其重要的一種,多維數(shù)組可以更加方便地組織數(shù)據(jù),提高Java應(yīng)用程序的效率,本文將為大家介紹Java中多維數(shù)組的基本概念和常用操作,助力讀者更好地掌握多維數(shù)組的使用技巧2023-11-11spring事務(wù)@Transactional失效原因及解決辦法小結(jié)
今天就跟大家聊聊有關(guān)spring中@Transactional失效原因及解決辦法小結(jié),主要從三個(gè)方面考慮,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08java基于Socket做一個(gè)簡(jiǎn)單下載器
這篇文章主要為大家詳細(xì)介紹了java如何基于Socket制作一個(gè)簡(jiǎn)單下載器,感興趣的小伙伴們可以參考一下2016-08-08