溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

詳解Spring MVC 集成EHCache緩存

發(fā)布時(shí)間:2020-09-06 20:43:20 來源:腳本之家 閱讀:184 作者:jiangadam 欄目:編程語(yǔ)言

廢話少說,直接上代碼:

ehcache.xml 文件

<?xml version="1.0" encoding="UTF-8"?>
<ehcache dynamicConfig="false" monitoring="off" updateCheck="false" 
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="ehcache.xsd"> 

  <!-- 定義緩存策略 
    eternal="false"         // 元素是否永恒,如果是就永不過期(必須設(shè)置) 
    maxEntriesLocalHeap="1000"   // 堆內(nèi)存中最大緩存對(duì)象數(shù),0沒有限制(必須設(shè)置) 
    overflowToDisk="false"     // 當(dāng)緩存達(dá)到maxElementsInMemory值是,是否允許溢出到磁盤(必須設(shè)置) 
    diskPersistent="false"     // 磁盤緩存在VM重新啟動(dòng)時(shí)是否保持(默認(rèn)為false) 
    timeToIdleSeconds="0"      // 導(dǎo)致元素過期的訪問間隔(秒為單位). 當(dāng)eternal為false時(shí),這個(gè)屬性才有效,0表示可以永遠(yuǎn)空閑,默認(rèn)為0 
    timeToLiveSeconds="600"     // 元素在緩存里存在的時(shí)間(秒為單位). 0 表示永遠(yuǎn)存在不過期 
    memoryStoreEvictionPolicy="LFU" // 當(dāng)達(dá)到maxElementsInMemory時(shí),如何強(qiáng)制進(jìn)行驅(qū)逐默認(rèn)使用"最近使用(LRU)"策略,其它還有先入先出FIFO,最少使用LFU,較少使用LRU 
  --> 

  <!--
    1)maxElementsInMemory(正整數(shù)):在內(nèi)存中緩存的最大對(duì)象數(shù)量
    2)maxElementsOnDisk(正整數(shù)):在磁盤上緩存的最大對(duì)象數(shù)量,默認(rèn)值為0,表示不限制。 
    3)eternal:設(shè)定緩存對(duì)象保存的永久屬性,默認(rèn)為 false 。當(dāng)為 true 時(shí) timeToIdleSeconds、timeToLiveSeconds 失效。 
    4)timeToIdleSeconds(單位:秒): 對(duì)象空閑時(shí)間,指對(duì)象在多長(zhǎng)時(shí)間沒有被訪問就會(huì)失效。只對(duì)eternal為false的有效。默認(rèn)值0,表示一直可以訪問。
    5)timeToLiveSeconds(單位:秒): 對(duì)象存活時(shí)間,指對(duì)象從創(chuàng)建到失效所需要的時(shí)間。只對(duì)eternal為false的有效。默認(rèn)值0,表示一直可以訪問。
    6)overflowToDisk:如果內(nèi)存中數(shù)據(jù)超過內(nèi)存限制,是否要緩存到磁盤上。 
    7)diskPersistent:是否在磁盤上持久化。指重啟jvm后,數(shù)據(jù)是否有效。默認(rèn)為false。 
  8)diskSpoolBufferSizeMB(單位:MB): DiskStore使用的磁盤大小,默認(rèn)值30MB。每個(gè)cache使用各自的DiskStore。
    9)memoryStoreEvictionPolicy:如果內(nèi)存中數(shù)據(jù)超過內(nèi)存限制,向磁盤緩存時(shí)的策略。默認(rèn)值LRU,可選FIFO、LFU。
    FIFO(first in first out):先進(jìn)先出
    LFU(Less Frequently Used):最少被使用,緩存的元素有一個(gè)hit屬性,hit值最小的將會(huì)被清除緩存。
    LRU(Least Recently Used)默認(rèn)策略:最近最少使用,緩存的元素有一個(gè)時(shí)間戳,當(dāng)緩存容量滿了,而又需要騰出地方來緩存新的元素的時(shí)候,那么現(xiàn)有緩存元素中時(shí)間戳離當(dāng)前時(shí)間最遠(yuǎn)的元素將被清除緩存。
  10) maxEntriesLocalHeap 堆內(nèi)存中最大緩存對(duì)象數(shù)  
  -->
    <diskStore path="java.io.tmpdir"></diskStore>
  <defaultCache 
    eternal="false" 
    maxEntriesLocalHeap="0" 
    timeToIdleSeconds="120" 
    timeToLiveSeconds="120"
    maxElementsInMemory="10000"
    overflowToDisk="true"
    diskPersistent="true"
  /> 

  <cache 
    name="userCache" 
    maxEntriesLocalHeap="10000" 
  />  
  <cache
    name="studentCache"
    maxEntriesLocalHeap="10000"
  />

</ehcache>

需要增加的JAR包

詳解Spring MVC 集成EHCache緩存

springmvc.xml 需要在beans增加以下

xmlns:cache="http://www.springframework.org/schema/cache"
http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache.xsd

增加bean

<!-- 啟用緩存注解功能(請(qǐng)將其配置在Spring主配置文件中) -->
<cache:annotation-driven cache-manager="cacheManager"/>  
<!-- Spring提供的基于的Ehcache實(shí)現(xiàn)的緩存管理器 -->  
<bean id="cacheManagerFactory" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">  
  <property name="configLocation" value="classpath:config/ehcache.xml"/>  
</bean>  
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">  
  <property name="cacheManager" ref="cacheManagerFactory"/>  
</bean>

EHCacheUtils 操作類

import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;

/**
 * 操作緩存類
 * 
 * @author jiangadam
 */

public class EhcacheUtils {

  private static final String path = "/config/ehcache.xml"; // EHCache 的配置文件地址

  private CacheManager manager;

  private static EhcacheUtils ehCache;

  private EhcacheUtils(String path) {
    manager = CacheManager.create(getClass().getResource(path));
  }

  public static EhcacheUtils getInstance() {
    if (ehCache == null) {
      ehCache = new EhcacheUtils(path);
    }
    return ehCache;
  }

  /**
   * 緩存一個(gè)對(duì)象
   * 
   * @param cacheName
   *      緩存的名字
   * @param key
   *      緩存的KEY
   * @param value
   *      緩存的值
   */
  public void put(String cacheName, String key, Object value) {
    Cache cache = manager.getCache(cacheName);
    Element element = new Element(key, value);
    cache.put(element);
  }

  /**
   * 獲取一個(gè)緩存的對(duì)象,沒有返回NULL
   * 
   * @param cacheName
   * @param key
   * @return
   */
  public Object get(String cacheName, String key) {
    Cache cache = manager.getCache(cacheName);
    Element element = cache.get(key);
    return element == null ? null : element.getObjectValue();
  }

  public Cache get(String cacheName) {
    return manager.getCache(cacheName);
  }

  public void remove(String cacheName, String key) {
    Cache cache = manager.getCache(cacheName);
    cache.remove(key);
  }

}

PUT 寫入緩存

詳解Spring MVC 集成EHCache緩存

GET 獲取緩存的數(shù)據(jù)

詳解Spring MVC 集成EHCache緩存

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

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

AI