中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Spring Boot中使用Redis緩存

發布時間:2021-06-09 18:12:31 來源:億速云 閱讀:141 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關怎么在Spring Boot中使用Redis緩存,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

首先創建一個Spring Boot工程,注意創建的時候需要引入三個依賴,web、cache以及redis,如下圖:

怎么在Spring Boot中使用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>

基本配置

工程創建好之后,首先需要簡單配置一下Redis,Redis的基本信息,另外,這里要用到Cache,因此還需要稍微配置一下Cache,如下:

spring.redis.port=6380 
spring.redis.host=192.168.66.128 
 
spring.cache.cache-names=c1

簡單起見,這里我只是配置了Redis的端口和地址,然后給緩存取了一個名字,這個名字在后文會用到。

另外,還需要在配置類上添加如下代碼,表示開啟緩存:

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

完成了這些配置之后,Spring Boot就會自動幫我們在后臺配置一個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()); 
} 
}

看類上的注解,發現在萬事俱備的情況下,系統會自動提供一個RedisCacheManager的Bean,這個RedisCacheManager間接實現了Spring中的Cache接口,有了這個Bean,我們就可以直接使用Spring中的緩存注解和接口了,而緩存數據則會被自動存儲到Redis上。在單機的Redis中,這個Bean系統會自動提供,如果是Redis集群,這個Bean需要開發者來提供(后面的文章會講到)。

緩存使用

這里主要向小伙伴們介紹緩存中幾個核心的注解使用。

@CacheConfig

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

@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 Boot中使用Redis緩存

@CachePut

這個注解一般加在更新方法上,當數據庫中的數據更新后,緩存中的數據也要跟著更新,使用該注解,可以將方法的返回值自動更新到已經存在的key上,示例代碼如下:

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

@CacheEvict

這個注解一般加在刪除方法上,當數據庫中的數據刪除后,相關的緩存數據也要自動清除,該注解在使用的時候也可以配置按照某種條件刪除(condition屬性)或者或者配置清除所有緩存(allEntries屬性),示例代碼如下:

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

以上就是怎么在Spring Boot中使用Redis緩存,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

尉氏县| 甘洛县| 瓮安县| 宜良县| 蕲春县| 望奎县| 门头沟区| 扎赉特旗| 盐山县| 钟祥市| 木兰县| 新津县| 扎鲁特旗| 岑溪市| 铁力市| 姚安县| 辽阳市| 华阴市| 高平市| 明溪县| 惠州市| 沙洋县| 荆门市| 鄱阳县| 扶沟县| 新乡市| 淅川县| 浏阳市| 滕州市| 镶黄旗| 旅游| 静宁县| 汤阴县| 阜南县| 奎屯市| 普宁市| 宁城县| 轮台县| 方正县| 孝昌县| 加查县|