Hier finden Sie ein vollständiges Beispiel für die Einrichtung des Guava-Cache im Frühjahr. Ich habe Guava über Ehcache verwendet, weil es etwas leichter ist und mir die Konfiguration direkter erschien.
Maven-Abhängigkeiten importieren
Fügen Sie diese Abhängigkeiten zu Ihrer Maven-POM-Datei hinzu und führen Sie Clean und Pakete aus. Diese Dateien sind die Guava dep- und Spring-Hilfsmethoden zur Verwendung im 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>
Konfigurieren Sie den Cache
Sie müssen eine CacheConfig-Datei erstellen, um den Cache mithilfe der Java-Konfiguration zu konfigurieren.
@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());
}
}
Kommentieren Sie die zwischengespeicherte Methode
Fügen Sie die Annotation @Cacheable hinzu und übergeben Sie den Cache-Namen.
@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();
}
}
Ein vollständigeres Beispiel mit kommentierten Screenshots finden Sie hier: Guava Cache in Spring