欧美日韩不卡一区二区三区,www.蜜臀.com,高清国产一区二区三区四区五区,欧美日韩三级视频,欧美性综合,精品国产91久久久久久,99a精品视频在线观看

java語(yǔ)言

Spring Boot基于注解的Redis緩存使用

時(shí)間:2025-05-09 08:54:17 java語(yǔ)言 我要投稿
  • 相關(guān)推薦

Spring Boot基于注解的Redis緩存使用

  Spring Boot是由Pivotal團(tuán)隊(duì)提供的全新框架,其設(shè)計(jì)目的是用來(lái)簡(jiǎn)化新Spring應(yīng)用的初始搭建以及開(kāi)發(fā)過(guò)程。本文主要介紹了Spring Boot 基于注解的 Redis 緩存使用詳解,下面百分網(wǎng)小編帶大家一起來(lái)看看詳細(xì)內(nèi)容,希望對(duì)大家有所幫助!想了解更多相關(guān)信息請(qǐng)持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!

  看文本之前,請(qǐng)先確定你看過(guò)上一篇文章《Spring Boot Redis 集成配置》并保證 Redis 集成后正?捎茫?yàn)楸疚氖腔谏衔睦^續(xù)增加的代碼。

  一、創(chuàng)建 Caching 配置類(lèi)

  RedisKeys.Java

  package com.shanhy.example.redis;

  import java.util.HashMap;

  import java.util.Map;

  import javax.annotation.PostConstruct;

  import org.springframework.stereotype.Component;

  /**

  * 方法緩存key常量

  *

  * @author SHANHY

  */

  @Component

  public class RedisKeys {

  // 測(cè)試 begin

  public static final String _CACHE_TEST = "_cache_test";// 緩存key

  public static final Long _CACHE_TEST_SECOND = 20L;// 緩存時(shí)間

  // 測(cè)試 end

  // 根據(jù)key設(shè)定具體的緩存時(shí)間

  private Map<String, Long> expiresMap = null;

  @PostConstruct

  public void init(){

  expiresMap = new HashMap<>();

  expiresMap.put(_CACHE_TEST, _CACHE_TEST_SECOND);

  }

  public Map<String, Long> getExpiresMap(){

  return this.expiresMap;

  }

  }

  CachingConfig.java

  package com.shanhy.example.redis;

  import java.lang.reflect.Method;

  import java.util.ArrayList;

  import java.util.List;

  import org.springframework.cache.CacheManager;

  import org.springframework.cache.annotation.CachingConfigurerSupport;

  import org.springframework.cache.annotation.EnableCaching;

  import org.springframework.cache.interceptor.KeyGenerator;

  import org.springframework.cache.interceptor.SimpleKeyGenerator;

  import org.springframework.context.annotation.Bean;

  import org.springframework.context.annotation.Configuration;

  import org.springframework.data.redis.cache.RedisCacheManager;

  import org.springframework.data.redis.core.RedisTemplate;

  /**

  * 注解式環(huán)境管理

  *

  * @author 單紅宇(CSDN catoop)

  * @create 2016年9月12日

  */

  @Configuration

  @EnableCaching

  public class CachingConfig extends CachingConfigurerSupport {

  /**

  * 在使用@Cacheable時(shí),如果不指定key,則使用找個(gè)默認(rèn)的key生成器生成的key

  *

  * @return

  *

  * @author 單紅宇(CSDN CATOOP)

  * @create 2017年3月11日

  */

  @Override

  public KeyGenerator keyGenerator() {

  return new SimpleKeyGenerator() {

  /**

  * 對(duì)參數(shù)進(jìn)行拼接后MD5

  */

  @Override

  public Object generate(Object target, Method method, Object... params) {

  StringBuilder sb = new StringBuilder();

  sb.append(target.getClass().getName());

  sb.append(".").append(method.getName());

  StringBuilder paramsSb = new StringBuilder();

  for (Object param : params) {

  // 如果不指定,默認(rèn)生成包含到鍵值中

  if (param != null) {

  paramsSb.append(param.toString());

  }

  }

  if (paramsSb.length() > 0) {

  sb.append("_").append(paramsSb);

  }

  return sb.toString();

  }

  };

  }

  /**

  * 管理緩存

  *

  * @param redisTemplate

  * @return

  */

  @Bean

  public CacheManager cacheManager(RedisTemplate<String, Object> redisTemplate, RedisKeys redisKeys) {

  RedisCacheManager rcm = new RedisCacheManager(redisTemplate);

  // 設(shè)置緩存默認(rèn)過(guò)期時(shí)間(全局的)

  rcm.setDefaultExpiration(1800);// 30分鐘

  // 根據(jù)key設(shè)定具體的緩存時(shí)間,key統(tǒng)一放在常量類(lèi)RedisKeys中

  rcm.setExpires(redisKeys.getExpiresMap());

  List<String> cacheNames = new ArrayList<String>(redisKeys.getExpiresMap().keySet());

  rcm.setCacheNames(cacheNames);

  return rcm;

  }

  }

  二、創(chuàng)建需要緩存數(shù)據(jù)的類(lèi)

  TestService.java

  package com.shanhy.example.service;

  import org.apache.commons.lang3.RandomStringUtils;

  import org.springframework.cache.annotation.Cacheable;

  import org.springframework.stereotype.Service;

  import com.shanhy.example.redis.RedisKeys;

  @Service

  public class TestService {

  /**

  * 固定key

  *

  * @return

  * @author SHANHY

  * @create 2017年4月9日

  */

  @Cacheable(value = RedisKeys._CACHE_TEST, key = "'" + RedisKeys._CACHE_TEST + "'")

  public String testCache() {

  return RandomStringUtils.randomNumeric(4);

  }

  /**

  * 存儲(chǔ)在Redis中的key自動(dòng)生成,生成規(guī)則詳見(jiàn)CachingConfig.keyGenerator()方法

  *

  * @param str1

  * @param str2

  * @return

  * @author SHANHY

  * @create 2017年4月9日

  */

  @Cacheable(value = RedisKeys._CACHE_TEST)

  public String testCache2(String str1, String str2) {

  return RandomStringUtils.randomNumeric(4);

  }

  }

  說(shuō)明一下,其中 @Cacheable 中的 value 值是在 CachingConfig的cacheManager 中配置的,那里是為了配置我們的緩存有效時(shí)間。其中 methodKeyGenerator 為 CachingConfig 中聲明的 KeyGenerator。

  另外,Cache 相關(guān)的注解還有幾個(gè),大家可以了解下,不過(guò)我們常用的就是 @Cacheable,一般情況也可以滿足我們的大部分需求了。還有 @Cacheable 也可以配置表達(dá)式根據(jù)我們傳遞的參數(shù)值判斷是否需要緩存。

  注: TestService 中 testCache 中的 mapper.get 大家不用關(guān)心,這里面我只是訪問(wèn)了一下數(shù)據(jù)庫(kù)而已,你只需要在這里做自己的業(yè)務(wù)代碼即可。

  三、測(cè)試方法

  下面代碼,隨便放一個(gè) Controller 中

  package com.shanhy.example.controller;

  import org.slf4j.Logger;

  import org.slf4j.LoggerFactory;

  import org.springframework.beans.factory.annotation.Autowired;

  import org.springframework.data.redis.connection.jedis.RedisClient;

  import org.springframework.web.bind.annotation.GetMapping;

  import org.springframework.web.bind.annotation.RequestMapping;

  import org.springframework.web.bind.annotation.RestController;

  import com.shanhy.example.service.TestService;

  /**

  * 測(cè)試Controller

  *

  * @author 單紅宇(365384722)

  * @create 2017年4月9日

  */

  @RestController

  @RequestMapping("/test")

  public class TestController {

  private static final Logger LOG = LoggerFactory.getLogger(TestController.class);

  @Autowired

  private RedisClient redisClient;

  @Autowired

  private TestService testService;

  @GetMapping("/redisCache")

  public String redisCache() {

  redisClient.set("shanhy", "hello,shanhy", 100);

  LOG.info("getRedisValue = {}", redisClient.get("shanhy"));

  testService.testCache2("aaa", "bbb");

  return testService.testCache();

  }

  }

  至此完畢!

【Spring Boot基于注解的Redis緩存使用】相關(guān)文章:

詳解Spring Boot Redis集成配置07-18

Spring Boot使用slf4j+logback記錄日志配置詳解08-16

Spring Boot如何實(shí)現(xiàn)日志記錄SLF4J08-31

如何使用php操作redis隊(duì)列實(shí)例09-15

php中使用redis隊(duì)列操作實(shí)例代碼05-16

用PHP基于Redis消息隊(duì)列實(shí)現(xiàn)發(fā)布微博的方法08-30

CPU緩存的作用10-26

PHP緩存技術(shù)10-08

java的緩存機(jī)制07-29