溫馨提示×

溫馨提示×

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

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

SpringBoot項目中使用redis緩存的方法步驟

發(fā)布時間:2020-09-10 12:41:29 來源:腳本之家 閱讀:177 作者:QiHaiYan 欄目:編程語言

本文介紹了SpringBoot項目中使用redis緩存的方法步驟,分享給大家,具體如下:

Spring Data Redis為我們封裝了Redis客戶端的各種操作,簡化使用。

- 當Redis當做數(shù)據(jù)庫或者消息隊列來操作時,我們一般使用RedisTemplate來操作

- 當Redis作為緩存使用時,我們可以將它作為Spring Cache的實現(xiàn),直接通過注解使用

1.概述

在應用中有效的利用redis緩存可以很好的提升系統(tǒng)性能,特別是對于查詢操作,可以有效的減少數(shù)據(jù)庫壓力。

具體的代碼參照該 示例項目

2.添加引用

在build.gradle加入

compile('org.springframework.boot:spring-boot-starter-data-redis')

SpringBoot會自動引入redis相關的jar包。加入該引用后,需要在本地安裝redis并啟動,否則程序啟動時會報錯。

3.通過注解啟用緩存

在SpringBoot中啟用redis非常簡單,只需要在Application主類上添加@EnableCaching注解,之后在需要啟用緩存的查詢方法上添加@Cacheable注解。

@SpringBootApplication
@EnableCaching
public class DemoApplication implements CommandLineRunner{
...

查詢接口:

public interface TestRepository extends JpaRepository<Test, Integer> {
  @Cacheable(value = "testCache")
  public Test findOne(Integer id);
}

實體類需要實現(xiàn)Serializable接口,否則程序會報錯,因為無法把java對象序列化到redis中。SpringBoot中redis默認使用DefaultSerializer,這個用的是jdk自身的序列化方法。

總共有以下幾種序列化方法,具體的使用場景可以參考官方文檔

1. GenericJackson2JsonRedisSerializer
2. GenericToStringSerializer
3. Jackson2JsonRedisSerializer
4. JacksonJsonRedisSerializer
5. JdkSerializationRedisSerializer
6. OxmSerializer
7. StringRedisSerializer

至此我們的程序就具有了從redis緩存中查詢數(shù)據(jù)的能力,如果對redis中存儲的KEY的美觀程度不介意的話,工作到此就結束了。

4.美觀的KEY

執(zhí)行我們的程序以后,在redis-cli中執(zhí)行KEY *命令,會發(fā)現(xiàn)key的值是一堆類似于亂碼的東西:

"testCache:\xac\xed\x00\x05sr\x00\x11java.lang.Integer\x12\xe2\xa0\xa4\xf7\x81\x878\x02\x00\x01I\x00\x05valuexr\x00\x10java.lang.Number\x86\xac\x95\x1d\x0b\x94\xe0\x8b\x02\x00\x00xp\x00\x00\x00\x01"
這中key值對于redis的運維人員來說估計是不可接受的,我們要想辦法讓key值變的好看一些,至少要讓人能看得懂。

出現(xiàn)上面的key值的原因就是spring中默認采用了SimpleKey這個類來生成redis的key。

解決方法也很簡單,增加緩存配置,指定redis生成key的方式:

@Configuration
public class CacheConfig extends CachingConfigurerSupport {

  @Autowired
  private RedisTemplate redisTemplate;

  @Bean
  public CacheManager cacheManager() {

    redisTemplate.setKeySerializer(new GenericToStringSerializer<Object>(Object.class));

    RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate);
    cacheManager.setDefaultExpiration(3600);
    cacheManager.setUsePrefix(true);
    cacheManager.setCachePrefix(new RedisCachePrefix() {
      private final RedisSerializer<String> serializer = new StringRedisSerializer();
      private final String delimiter = ":";

      public byte[] prefix(String cacheName) {
        return this.serializer
            .serialize(cacheName.concat(this.delimiter));
      }
    });

    return cacheManager;
  }
}

其中

復制代碼 代碼如下:

redisTemplate.setKeySerializer(new GenericToStringSerializer<Object>(Object.class));

這行代碼指定了redis中key值的生成方式,GenericToStringSerializer這個序列化方法會把java對象轉(zhuǎn)換為字符串存儲到redis中。

5.總結

在SpringBoot中啟用redis緩存非常簡單,只需要加幾個注解即可。同時我們可以通過增加緩存配置的方式,讓存儲到redis中的key值具有良好的可讀性,而不是一堆類似于亂碼的數(shù)據(jù)。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

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

AI