1. 程式人生 > 程式設計 >Spring Cache整合Redis實現方法詳解

Spring Cache整合Redis實現方法詳解

匯入依賴

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
</dependency>

基本配置

spring.redis.port=6380
spring.redis.host=192.168.66.128

spring.cache.cache-names=c1 //給快取取了一個名字

在啟動類上添加註解,表示開啟快取

完成了這些配置之後,Spring Boot就會自動幫

@SpringBootApplication
@EnableCaching
public class RediscacheApplication {

 public static void main(String[] args) {
  SpringApplication.run(RediscacheApplication.class,args);
 }

}

我們在後臺配置一個RedisCacheManager,相關的配置是在org.springframework.boot.autoconfigure.cache.RedisCacheConfiguration類中完成的。部分原始碼如下:

@Configuration
@ConditionalOnClass(RedisConnectionFactory.class)
@AutoConfigureAfter(RedisAutoConfiguration.class)
@ConditionalOnBean(RedisConnectionFactory.class)
@ConditionalOnMissingBean(CacheManager.class)
@Conditional(CacheCondition.class)
class RedisCacheConfiguration {

	@Bean
	public RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory,ResourceLoader resourceLoader) {
		RedisCacheManagerBuilder builder = RedisCacheManager
				.builder(redisConnectionFactory)
				.cacheDefaults(determineConfiguration(resourceLoader.getClassLoader()));
		List<String> cacheNames = this.cacheProperties.getCacheNames();
		if (!cacheNames.isEmpty()) {
			builder.initialCacheNames(new LinkedHashSet<>(cacheNames));
		}
		return this.customizerInvoker.customize(builder.build());
	}
}

系統會自動提供一個RedisCacheManger的Bean,RedisCacheManager間接實現了Spring中的Cache介面,有了這個Bean,我們就可以直接使用Spring中的快取註解和介面了,而快取資料則會被自動儲存到Redis上。

在單機的Redis中,這個Bean系統會自動提供,如果是Redis叢集,這個Bean需要開發者來提供

快取使用@CachaConfig

這個註解在類上使用,用來描述該類中所有方法使用的快取名稱,當然也可以不使用該註解,直接在具體的快取註解上配置名稱,示例程式碼如下:

@Service
@CacheConfig(cacheNames = "c1")
public class UserService {
}

@Cacheable

這個註解一般載入查詢方法上,表示將一個方法的返回值快取起來,預設情況下,快取的key就是方法的引數,快取的value就是方法的返回值,示例程式碼如下:

@Cacheable(key = "#id")
public User getUserById(Integer id,String username) {
 System.out.println("getUserById");
 return getUserFromDBById(id);
}

當有多個引數時,預設就使用多個引數來做key,如果只需要其中某一個引數做key,則可以在@Cacheable註解中,通過key屬性來指定key,如上程式碼就表示只使用id作為快取的key,如果對key有複雜的要求,可以自定義keyGenerator。當然,Spring Cache中提供了root物件,可以在不定義keyGenerator的情況下實現一些複雜的效果:

Spring Cache整合Redis實現方法詳解

@CachePut

這個註解一般加在更新方法上,當資料庫中的資料更新後,快取中的資料也要跟著更新,使用該註解,可以將方法的返回值自動更新到已經存在的key上,示例程式碼如下:

@CachePut(key = "#user.id")
public User updateUserById(User user) {
 return user;
}

@CacheEvict

這個註解一般加在刪除方法上,當資料庫中的資料刪除後,相關的快取資料也要自動清除,該註解在使用的時候也可以配置按照某種條件刪除(condition屬性)或者或者配置清除所有快取(allEntries屬性),示例程式碼如下:

@CacheEvict()
public void deleteUserById(Integer id) {
 //在這裡執行刪除操作, 刪除是去資料庫中刪除
}

總結

在SpringBoot中,使用Redis快取,既可以使用RedisTemplate自己來實現,也可以使用使用這種方式,這種方式是Spring
Cache提供的統一介面,實現既可以是Redis,也可以是Ehcache或者其他支援這種規範的快取框架。從這個角度來說,SpringCache和Redis、Ehcache的關係就像JDBC與各種資料庫驅動的關係。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。