Oto pełny przykład konfiguracji Guava Cache na wiosnę. Użyłem guawy zamiast Ehcache, ponieważ jest nieco lżejszy, a konfiguracja wydawała mi się prostsza.
Importuj zależności Maven
Dodaj te zależności do pliku pom maven i uruchom czyste i pakiety. Te pliki są metodami pomocniczymi Guava dep i Spring do użycia w CacheBuilder.
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>18.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>4.1.7.RELEASE</version>
</dependency>
Skonfiguruj pamięć podręczną
Musisz utworzyć plik CacheConfig, aby skonfigurować pamięć podręczną przy użyciu konfiguracji Java.
@Configuration
@EnableCaching
public class CacheConfig {
public final static String CACHE_ONE = "cacheOne";
public final static String CACHE_TWO = "cacheTwo";
@Bean
public Cache cacheOne() {
return new GuavaCache(CACHE_ONE, CacheBuilder.newBuilder()
.expireAfterWrite(60, TimeUnit.MINUTES)
.build());
}
@Bean
public Cache cacheTwo() {
return new GuavaCache(CACHE_TWO, CacheBuilder.newBuilder()
.expireAfterWrite(60, TimeUnit.SECONDS)
.build());
}
}
Opisz metodę, która ma być buforowana
Dodaj adnotację @Cacheable i podaj nazwę pamięci podręcznej.
@Service
public class CachedService extends WebServiceGatewaySupport implements CachedService {
@Inject
private RestTemplate restTemplate;
@Cacheable(CacheConfig.CACHE_ONE)
public String getCached() {
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
HttpEntity<String> reqEntity = new HttpEntity<>("url", headers);
ResponseEntity<String> response;
String url = "url";
response = restTemplate.exchange(
url,
HttpMethod.GET, reqEntity, String.class);
return response.getBody();
}
}
Możesz zobaczyć bardziej kompletny przykład tutaj z opisami zrzutów ekranu: Guava Cache in Spring