廢話少說,直接上代碼:
為尼木等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及尼木網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、尼木網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
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)存中最大緩存對象數(shù),0沒有限制(必須設(shè)置) overflowToDisk="false" // 當(dāng)緩存達(dá)到maxElementsInMemory值是,是否允許溢出到磁盤(必須設(shè)置) diskPersistent="false" // 磁盤緩存在VM重新啟動時是否保持(默認(rèn)為false) timeToIdleSeconds="0" // 導(dǎo)致元素過期的訪問間隔(秒為單位). 當(dāng)eternal為false時,這個屬性才有效,0表示可以永遠(yuǎn)空閑,默認(rèn)為0 timeToLiveSeconds="600" // 元素在緩存里存在的時間(秒為單位). 0 表示永遠(yuǎn)存在不過期 memoryStoreEvictionPolicy="LFU" // 當(dāng)達(dá)到maxElementsInMemory時,如何強(qiáng)制進(jìn)行驅(qū)逐默認(rèn)使用"最近使用(LRU)"策略,其它還有先入先出FIFO,最少使用LFU,較少使用LRU --> <!-- 1)maxElementsInMemory(正整數(shù)):在內(nèi)存中緩存的最大對象數(shù)量 2)maxElementsOnDisk(正整數(shù)):在磁盤上緩存的最大對象數(shù)量,默認(rèn)值為0,表示不限制。 3)eternal:設(shè)定緩存對象保存的永久屬性,默認(rèn)為 false 。當(dāng)為 true 時 timeToIdleSeconds、timeToLiveSeconds 失效。 4)timeToIdleSeconds(單位:秒): 對象空閑時間,指對象在多長時間沒有被訪問就會失效。只對eternal為false的有效。默認(rèn)值0,表示一直可以訪問。 5)timeToLiveSeconds(單位:秒): 對象存活時間,指對象從創(chuàng)建到失效所需要的時間。只對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。每個cache使用各自的DiskStore。 9)memoryStoreEvictionPolicy:如果內(nèi)存中數(shù)據(jù)超過內(nèi)存限制,向磁盤緩存時的策略。默認(rèn)值LRU,可選FIFO、LFU。 FIFO(first in first out):先進(jìn)先出 LFU(Less Frequently Used):最少被使用,緩存的元素有一個hit屬性,hit值最小的將會被清除緩存。 LRU(Least Recently Used)默認(rèn)策略:最近最少使用,緩存的元素有一個時間戳,當(dāng)緩存容量滿了,而又需要騰出地方來緩存新的元素的時候,那么現(xiàn)有緩存元素中時間戳離當(dāng)前時間最遠(yuǎn)的元素將被清除緩存。 10) maxEntriesLocalHeap 堆內(nèi)存中最大緩存對象數(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包
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
<!-- 啟用緩存注解功能(請將其配置在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; } /** * 緩存一個對象 * * @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); } /** * 獲取一個緩存的對象,沒有返回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 寫入緩存
GET 獲取緩存的數(shù)據(jù)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
文章名稱:詳解SpringMVC集成EHCache緩存
標(biāo)題來源:http://jinyejixie.com/article36/ggsjsg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、電子商務(wù)、微信小程序、用戶體驗(yàn)、商城網(wǎng)站、定制開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)