springboot使用Redis緩存

1.導入Maven依賴

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

<!-- spring集成redis所需common-pool2-->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
    <version>2.8.1</version>
</dependency>

2.添加redis配置類

@EnableCaching
@Configuration
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);
        //解決查詢緩存轉換異常的問題
        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.添加springboot緩存註解

一般用第一種

(1)緩存@Cacheable

根據方法對其返回結果進行緩存,下次請求時,如果緩存存在,則直接讀取緩存數據返回;如果緩存不存在,則執行方法,並把返回的結果存入緩存中。一般用在查詢方法上。

查看源碼,屬性值如下:

屬性/方法名 解釋
value 緩存名,必填,它指定了你的緩存存放在哪塊命名空間
cacheNames 與 value 差不多,二選一即可
key 可選屬性,可以使用 SpEL 標籤自定義緩存的key

(2)緩存@CachePut

使用該註解標誌的方法,每次都會執行,並將結果存入指定的緩存中。其他方法可以直接從響應的緩存中讀取緩存數據,而不需要再去查詢數據庫。一般用在新增方法上。

查看源碼,屬性值如下:

屬性/方法名 解釋
value 緩存名,必填,它指定了你的緩存存放在哪塊命名空間
cacheNames 與 value 差不多,二選一即可
key 可選屬性,可以使用 SpEL 標籤自定義緩存的key

(3)緩存@CacheEvict

使用該註解標誌的方法,會清空指定的緩存。一般用在更新或者刪除方法上

查看源碼,屬性值如下:

屬性/方法名 解釋
value 緩存名,必填,它指定了你的緩存存放在哪塊命名空間
cacheNames 與 value 差不多,二選一即可
key 可選屬性,可以使用 SpEL 標籤自定義緩存的key
allEntries 是否清空所有緩存,默認爲 false。如果指定爲 true,則方法調用後將立即清空所有的緩存
beforeInvocation 是否在方法執行前就清空,默認爲 false。如果指定爲 true,則在方法執行前就會清空緩存

4.編寫Redis配置文件

用properties來配置

spring.redis.host=服務器地址
spring.redis.port=6379
# Redis服務器連接密碼(默認爲空)
spring.redis.password=
spring.redis.database= 0
spring.redis.timeout=1800000
spring.redis.lettuce.pool.max-active=20
spring.redis.lettuce.pool.max-wait=-1
#最大阻塞等待時間(負數表示沒限制)
spring.redis.lettuce.pool.max-idle=5
spring.redis.lettuce.pool.min-idle=0

附常用命令

在ubuntu下

得到所有的鍵

keys *

打開配置文件

vim /etc/redis/redis.conf

重啓Redis服務

sudo /etc/init.d/redis-server restart

關閉Redis服務

sudo /etc/init.d/redis-server stop

開啓Redis服務

sudo /etc/init.d/redis-server start
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章