91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

springboot緩存的使用實踐

發布時間:2020-09-26 07:49:54 來源:腳本之家 閱讀:164 作者:luckyxl029 欄目:編程語言

spring針對各種緩存實現,抽象出了CacheManager接口,用戶使用該接口處理緩存,而無需關心底層實現。并且也可以方便的更改緩存的具體實現,而不用修改業務代碼。下面對于在springboot中使用緩存做一簡單介紹:

1、添加依賴

<dependency> 
  <groupId>org.springframework.boot</groupId> 
  <artifactId>spring-boot-starter-cache</artifactId> 
</dependency> 

2、在配置類里開啟緩存,如下圖所示:

springboot緩存的使用實踐

3、在需要使用緩存的方法上加上注解,如下:

@Override 
  //@CachePut 該注解會將方法的返回值緩存起來,其中緩存名字是 people,數據的key是person的id 
  @CachePut(value = "people", key = "#person.id") 
  public Person save(Person person) { 
    Person p = personRepository.save(person); 
    System.out.println("為id、key為:"+p.getId()+"數據做了緩存"); 
    return p; 
  } 
@Override 
  //@CacheEvict 該注解會刪除people緩存中key為id 的數據 
  @CacheEvict(value = "people", key = "#id") 
  public void remove(Long id) { 
    System.out.println("刪除了id、key為"+id+"的數據緩存"); 
    //這里不做實際刪除操作 
  }
@Override 
  //@Cacheable 該注解會在方法執行時,判斷緩存people中key為#person.id 
的緩存是否存在,如果存在,則直接返回緩存中的數據。如果不存在,則會查數據庫,然后將返回結果緩存起來。 
  @Cacheable(value = "people", key = "#person.id") 
  public Person findOne(Person person) { 
    Person p = personRepository.findOne(person.getId()); 
    System.out.println("為id、key為:"+p.getId()+"數據做了緩存"); 
    return p; 
  }

以上幾部就完成了緩存,但是現在的緩存是默認的基于內存的,沒有實現持久化。下面以redis作為緩存的具體實現,如下:

4、添加依賴

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

5、在配置文件里添加redis配置

redis.hostname=localhost 
redis.port=6379 

6、在spring容器中配置redis

@Configuration 
public class RedisConfig extends CachingConfigurerSupport{ 
  private static final Logger logger = LoggerFactory.getLogger(RedisConfig.class); 
 
  @Autowired 
  private Environment env; 
 
  @Bean 
  public JedisConnectionFactory redisConnectionFactory() { 
    JedisConnectionFactory redisConnectionFactory = new JedisConnectionFactory(); 
    redisConnectionFactory.setHostName(env.getProperty("redis.hostname")); 
    redisConnectionFactory.setPort(Integer.parseInt(env.getProperty("redis.port"))); 
    return redisConnectionFactory; 
  } 
 
  @Bean 
  public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory cf) { 
    RedisTemplate<String, String> redisTemplate = new RedisTemplate<>(); 
    redisTemplate.setConnectionFactory(cf); 
    return redisTemplate; 
  } 
 
  @Bean 
  public CacheManager cacheManager(RedisTemplate<?, ?> redisTemplate) { 
    RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate); 
    cacheManager.setDefaultExpiration(600); 
    return cacheManager; 
  } 
   
} 

ok,完成了,其他什么都不用改,是不是很方便?

另外,要緩存的類必須序列化。

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

向AI問一下細節

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

AI

海城市| 古田县| 芜湖县| 洛扎县| 雷波县| 云和县| 丘北县| 临武县| 彭泽县| 鹿泉市| 夹江县| 三河市| 泌阳县| 关岭| 兴仁县| 象山县| 清远市| 本溪市| 高唐县| 揭东县| 泸定县| 旬阳县| 河津市| 清徐县| 宽城| 共和县| 右玉县| 建阳市| 广丰县| 新野县| 太湖县| 巴彦淖尔市| 托克托县| 平南县| 太仓市| 三都| 合川市| 德惠市| 琼结县| 蒙城县| 临桂县|