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

溫馨提示×

溫馨提示×

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

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

SpringBoot中怎么利用Redis緩存數據

發布時間:2021-07-08 17:08:15 來源:億速云 閱讀:188 作者:Leah 欄目:編程語言

本篇文章為大家展示了SpringBoot中怎么利用Redis緩存數據,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

1.啟用對緩存的支持

spring對緩存的支持有兩種方式:

a.注解驅動的緩存

b.XML聲明的緩存

本文主要介紹純Java配置的緩存,那么必須在配置類上添加@EnableCaching,這樣的話就能啟動注解驅動的緩存。

2.使用Redis緩存

緩存的條目不過是一個鍵值對(Key-Value),其中key描述了產生value的操作和參數,因此會很自然的想到Redis。

Redis可以用來為srping緩存抽象機制緩存條目,Spring-Data-Redis提供了RedisCacheManager,這是CacheManager的一個實現。RedisCacheManager會與Redis服務器協作,通過RedisTemplate將緩存條目儲存到Redis中。

為了使用RedisCacheManager,我們需要RedisTmeplate Bean配置以及RedisConnectionFactory實現類(JedisConnectionFactory Bean配置)。

3.配置將緩存條目存儲在Redis服務器的緩存管理器。

前提需要在pom.xml引入

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

在application.properties中配置redis連接相關參數

#配置redis#在RedisProperties.class有redis的默認配置,默認host為localhost,默認端口為6379spring.redis.host=127.0.0.1spring.redis.port=6379

配置緩存管理器

package com.niugang;import java.lang.reflect.Method;import org.springframework.cache.CacheManager;import org.springframework.cache.annotation.EnableCaching;import org.springframework.cache.interceptor.KeyGenerator;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.cache.RedisCacheManager;import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;import org.springframework.data.redis.serializer.StringRedisSerializer;import com.fasterxml.jackson.annotation.PropertyAccessor;import com.fasterxml.jackson.databind.ObjectMapper;import com.fasterxml.jackson.annotation.JsonAutoDetect;@Configuration//沒有@EnableCaching這個注解的話,代碼不會報錯,就是內容不會放入redis中@EnableCaching public class RedisConfig {/*** 緩存管理器,不管用什么的緩存,都必須有緩存管理器*/@Beanpublic CacheManager cacheManager() {RedisCacheManager redisCacheManager = new RedisCacheManager(redisTemplate());/** 設置緩存保留的時間,默認是永久保存*/redisCacheManager.setDefaultExpiration(60);return redisCacheManager;}@Beanpublic JedisConnectionFactory jedisConnectionFactory() {JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();jedisConnectionFactory.afterPropertiesSet();return jedisConnectionFactory;}   /*** redis默認對象序列化是通過jdk來序列化的,這里面不用默認序列化方式,用JackJson進行序列化* * 設置key的類型為String類型* * @return*/@Bean@SuppressWarnings({ "rawtypes", "unchecked" })public RedisTemplate<String, String> redisTemplate() {RedisTemplate<String, String> redisTemplate = new RedisTemplate<String, String>();redisTemplate.setConnectionFactory(jedisConnectionFactory());     // 使用Jackson2JsonRedisSerialize 替換默認序列化Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);ObjectMapper objectMapper = new ObjectMapper();objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(objectMapper);// 設置value的序列化規則和 key的序列化規則redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);redisTemplate.setKeySerializer(new StringRedisSerializer());redisTemplate.afterPropertiesSet();return redisTemplate;} /**   * 生產key的策略   * @return   */@Bean   public KeyGenerator wiselyKeyGenerator(){     return new KeyGenerator() {       @Override       public Object generate(Object target, Method method, Object... params) {         StringBuilder sb = new StringBuilder();         sb.append(target.getClass().getName());         sb.append(method.getName());         for (Object obj : params) {           sb.append(obj.toString());         }                 return sb.toString();       }     };}}

4.為方法添加注解以支持緩存

spring的緩存抽象在很大程度上是圍繞切面構建的,在sprng中啟用緩存時,會創建一個切面,它觸發

一個或更多的spring的緩存注解。

spring提供了四個注解來聲明緩存規則

5.填充緩存

@Cacheable和CachePut都可以填充緩存,他們之間還是確有差異的。

@Cacheable和CachePut共同的屬性

6.自定義key

@Cacheable和CachePut都有一個名為key的屬性,這個屬性能夠替代默認的key,t它是通過SpEl(Spring El表達式)表達式計算得到的。具體到我們的業務場景 save(User user),我們需要將key設置保存為User對象中的id,我們通過mysql數據庫自動生成id,此時參數中的User對象還沒有id.幸好有SpEl。

7.在UserService中添加如下方法。

/*** 查詢全部* * @Cacheable,先在緩存中找,有則直接返回,不去調用方法,沒有則調用方法,將結果放入緩存中* * * 默認的key是基于方法參數來確定的,queryList()這個方法沒有參數,所以需要生成key的策略*///@Cacheable(value="findAll",keyGenerator="wiselyKeyGenerator")public List<User> queryList() {return userDao.findAll();}   /*** @Cachable會條件性的出發對方法的調用,這個取決于緩存中是不是已經有所需要的值。對于* 所注解的方法,@CachePut采用一種更為直接的流程。帶有@CachePut注解的方法始終都會調用,* 而的返回值也會放入到緩存中。* @CachePut先將對象保存到db中,返回的對象User中的id作為緩存中的key* result能夠得到返回的User* @param user*/@CachePut(value="save",key="#result.id.toString()")@Transactionalpublic User save(User user) {log.info("添加對象");return userDao.save(user);}  /*** 函數功能:根據id查詢* * 當get被調用時,緩存切面會攔截調用并在緩存中查找之前以名findOne存儲的返回值。緩存的key是* 傳遞到get()方法的id參數,這個參數還必須是String類型。如果按照這個key能* 夠找到值得話就返回找到的值,方法不會在被調用。如果沒有找到值的話,那就會調用這個方法* 并將返回值放到緩存之中。* * 默認是以參數id的值作為緩存中的key的* * 沒有添加key="#id.toString()" 可能為報java.lang.Integer cannot be cast to java.lang.String* 因為key的類型為String類型*/@Cacheable(value="findOne",key="#id.toString()")public User get(Integer id) {log.info("從數據查詢id為:{}的對象",id);return userDao.findOne(id);}   /*** 刪除 * @CacheEvict移除條目,可以用在返回值為void的方法上,但是@Cacheable,@CachePut不能用在返回值為void的方法上* * @param id*/@CacheEvict(value="save",key="#id.toString()")@Transactionalpublic void delete(int id) {log.info("從數據刪除id為:{}的對象",id);userDao.delete(id);}

上述內容就是SpringBoot中怎么利用Redis緩存數據,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

峨边| 汝州市| 孙吴县| 乐清市| 托里县| 黎川县| 河北省| 新田县| 买车| 延寿县| 江北区| 罗田县| 元阳县| 临江市| 高邮市| 博乐市| 富蕴县| 内丘县| 科尔| 额济纳旗| 遂昌县| 濉溪县| 禄劝| 红原县| 胶南市| 柳林县| 麻阳| 卓尼县| 京山县| 阜城县| 玛纳斯县| 望江县| 连州市| 穆棱市| 洱源县| 万载县| 米泉市| 柘荣县| 比如县| 渭源县| 翁牛特旗|