使用SpringCache加Redis做緩存
Redis + SpringCache
1. 添加依賴
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- spring2.X集成redis所需common-pool2-->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.6.0</version>
</dependency>
2. 使用配置類注入相關(guān)組件
@Configuration
@EnableCaching
public class RedisConfig extends CachingConfigurerSupport {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> template = new RedisTemplate<>();
RedisSerializer<String> redisSerializer = new StringRedisSerializer();
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(om);
template.setConnectionFactory(factory);
//key序列化方式
template.setKeySerializer(redisSerializer);
//value序列化
template.setValueSerializer(jackson2JsonRedisSerializer);
//value hashmap序列化
template.setHashValueSerializer(jackson2JsonRedisSerializer);
return template;
}
@Bean
public CacheManager cacheManager(RedisConnectionFactory factory) {
RedisSerializer<String> redisSerializer = new StringRedisSerializer();
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
//解決查詢緩存轉(zhuǎn)換異常的問題
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(om);
// 配置序列化(解決亂碼的問題),過期時間600秒
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofSeconds(600))
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
.disableCachingNullValues();
RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
.cacheDefaults(config)
.build();
return cacheManager;
}
}
3. 使用以下注解
@Cacheable:根據(jù)方法對返回結(jié)果進行緩存,下次請求時,如果緩存存在,則直接讀取緩存數(shù)據(jù)返回,如果緩存不存在,則執(zhí)行方法,并把返回結(jié)果存入緩存,一般用在查詢方法上@CachePut:每次都會執(zhí)行方法,并將結(jié)果存入緩存,其他方法可以直接讀取,一般用在新增方法上@CacheEvict:會清除指定的緩存,一般用在更新或刪除方法上
注解1和2的屬性
| 注解屬性 | 作用 |
|---|---|
| value | 必填,緩存名,指定命名空間 |
| cacheNames | 和value類似 |
| key | 可選,可以用spEL自定義key |
注解3多出兩個
| 注解屬性 | 作用 |
|---|---|
| allEntries | 如果指定為true,方法調(diào)用將清空所有緩存 |
| beforeInvocation | 是否在方法執(zhí)前清空,默認為false |
4. 配置
spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.database= 0 spring.redis.timeout=1800000
5. 存儲格式
value + "::" + key 的格式
例如:
@Cacheable(value = "space", key = "'key'")
緩存的鍵就是:
space::key
6. 注意點
key中如果是字符串需要加單引號,如果是spEL則不需要
Redis做緩存和SpringCache緩存
記錄一下Redis做緩存和SpringCache緩存的區(qū)別
1.Redis做緩存的話,相當于是一個第三方緩存,所以項目重啟之后緩存數(shù)據(jù)還是存在的
2.SpringCache作緩存的話是建立在JVM上的,所以項目啟動之后緩存是自動消失的。
業(yè)務(wù):在郵件驗證碼、短信驗證碼情況下需要設(shè)置過期時間。
如何使用:用Redis和SpringCache兩種使用方法。
過期時間:如果需要設(shè)置過期時間的話,需要使用到redis。如果不需要設(shè)置過期時間,則Redis和SpringCache都可以。
SpringCache 使用方法
1.在啟動類使用@EnableCaching
@SpringBootApplication
@EnableCaching //啟動SpringCache緩存
public class GatheringApplication {}
2.是需要添加緩存的時候使用@Cacheable
//存入緩存
@Cacheable(value = "gathering",key = "#id")
public Gathering findById(String id){}3.在需要刪除緩存的時候使用@CacheEvict
//刪除
@CacheEvict(value = "gathering",key = "#gathering.id")
public void update(Gathering gathering){}
下面是SpringDataRedis的部分使用方法:
/**
* 參數(shù)1:key 參數(shù)2:value 參數(shù)3:時間 參數(shù)4:時間單位
*/
redisTemplate.opsForValue().set(REDIS_ARTICLE_KEY+"_"+id,article,10, TimeUnit.SECONDS);
stringRedisTemplate.opsForValue().set("test", "100",60*10,TimeUnit.SECONDS);//向redis里存入數(shù)據(jù)和設(shè)置緩存時間
stringRedisTemplate.opsForValue().get("test")//根據(jù)key獲取緩存中的val
stringRedisTemplate.boundValueOps("test").increment(-1);//val做-1操作
stringRedisTemplate.boundValueOps("test").increment(1);//val +1
stringRedisTemplate.getExpire("test")//根據(jù)key獲取過期時間
stringRedisTemplate.getExpire("test",TimeUnit.SECONDS)//根據(jù)key獲取過期時間并換算成指定單位
stringRedisTemplate.delete("test");//根據(jù)key刪除緩存
stringRedisTemplate.hasKey("546545");//檢查key是否存在,返回boolean值
stringRedisTemplate.expire("red_123",1000 , TimeUnit.MILLISECONDS);//設(shè)置過期時間
stringRedisTemplate.opsForSet().add("red_123", "1","2","3");//向指定key中存放set集合
stringRedisTemplate.opsForSet().isMember("red_123", "1")//根據(jù)key查看集合中是否存在指定數(shù)據(jù)
stringRedisTemplate.opsForSet().members("red_123");//根據(jù)key獲取set集合
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java split函數(shù)拆分后變成null問題解決方案
這篇文章主要介紹了Java split函數(shù)拆分后變成null問題解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-10-10
Java數(shù)據(jù)結(jié)構(gòu)之隊列(動力節(jié)點Java學院整理)
隊列(Queue)是只允許在一端進行插入,而在另一端進行刪除的運算受限的線性表。 這篇文章詳細給大家介紹了java數(shù)據(jù)結(jié)構(gòu)之隊列,感興趣的朋友跟隨小編一起學習吧2017-04-04
解決mybatis三表連接查詢數(shù)據(jù)重復(fù)的問題
這篇文章主要介紹了解決mybatis三表連接查詢數(shù)據(jù)重復(fù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

