在目前流行的三種開源的緩存工具中,OSCache的配置和使用應給是最簡單的了,它主要是針對頁面級的配置,EHCache主要針對對象級的緩存,MemCached應該是比較完整的了。
下面我來總結一下OSCache,下面是網上找的兩篇文章介紹:
從 https://oscache.dev.java.net/files/documents/629/61427/oscache-2.4.1-full.zip 下載
下面轉自 http://www.javaeye.com/topic/172186
OSCache是當前運用最廣的緩存方案,JBoss,Hibernate,Spring等都對其有支持,
下面簡單介紹一下OSCache的配置和使用過程。
1.安裝過程
從http://www.opensymphony.com/oscache/download.html下載合適的OSCache版本,
我下載的是oscache-2.0.2-full版本。
解壓縮下載的文件到指定目錄
從解壓縮目錄取得oscache.jar 文件放到 /WEB-INF/lib 或相應類庫目錄 目錄中,
jar文件名可能含有版本號和該版本的發佈日期信息等,如oscache-2.0.2-22Jan04.jar
如果你的jdk版本爲1.3.x,建議在lib中加入Apache Common Lib 的commons-collections.jar包。
如jdk是1.4以上則不必
從src或etc目錄取得oscache.properties 文件,放入src根目錄或發佈環境的/WEB-INF/classes 目錄
如你需要建立磁盤緩存,須修改oscache.properties 中的cache.path信息 (去掉前面的#註釋)。
win類路徑類似爲c://app//cache
unix類路徑類似爲/opt/myapp/cache
拷貝OSCache標籤庫文件oscache.tld到/WEB-INF/classes目錄。
現在你的應用目錄類似如下:
$WEB_APPLICATION/WEB-INF/lib/oscache.jar
$WEB_APPLICATION/WEB-INF/classes/oscache.properties
$WEB_APPLICATION/WEB-INF/classes/oscache.tld
將下列代碼加入web.xml文件中
<taglib>
<taglib-uri>oscache</taglib-uri>
<taglib-location>/WEB-INF/classes/oscache.tld</taglib-location>
</taglib>
爲了便於調試日誌輸出,須加入commons-logging.jar和log4j-1.2.8.jar到當前類庫路徑中
在src目錄加入下面兩個日誌輸出配置文件:
log4j.properties 文件內容爲:
log4j.rootLogger=DEBUG,stdout,file
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[start]%d{yyyy/MM/dd/ HH:mm:ss}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=oscache.log
log4j.appender.file.MaxFileSize=100KB
log4j.appender.file.MaxBackupIndex=5
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[start]%d{yyyy/MM/dd/ HH:mm:ss}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
log4j.logger.org.apache.commons=ERROR
log4j.logger.com.opensymphony.oscache.base=INFO
commons-logging.properties 文件內容爲
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JCategoryLog
2.oscache.properties 文件配置嚮導
cache.memory
值爲true 或 false ,默認爲在內存中作緩存,
如設置爲false,那cache只能緩存到數據庫或硬盤中,那cache還有什麼意義:)
cache.capacity
緩存元素個數
cache.persistence.class
持久化緩存類,如此類打開,則必須設置cache.path信息
cache.cluster 相關
爲集羣設置信息。
如
cache.cluster.multicast.ip爲廣播IP地址
cache.cluster.properties爲集羣屬性
3.OSCache的基本用法
cache1.jsp 內容如下
<%@ page import="java.util.*" %>
<%@ taglib uri="oscache" prefix="cache" %>
<html>
<body>
沒有緩存的日期: <%= new Date() %><p>
<!--自動刷新-->
<cache:cache time="30">
每30秒刷新緩存一次的日期: <%= new Date() %>
</cache:cache>
<!--手動刷新-->
<cache:cache key="testcache">
手動刷新緩存的日期: <%= new Date() %> <p>
</cache:cache>
<a href="cache2.jsp">手動刷新</a>
</body>
</html>
cache2.jsp 執行手動刷新頁面如下
<%@ taglib uri="oscache" prefix="cache" %>
<html>
<body>
緩存已刷新...<p>
<cache:flush key="testcache" scope="application"/>
<a href="cache1.jsp">返回</a>
</body>
</html>
你也可以通過下面語句定義Cache的有效範圍,如不定義scope,scope默認爲Applcation
<cache:cache time="30" scope="session">
...
</cache:cache>
4. 緩存過濾器 CacheFilter
你可以在web.xml中定義緩存過濾器,定義特定資源的緩存。
<filter>
<filter-name>CacheFilter</filter-name>
<filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>
<init-param>
<param-name>time</param-name>
<param-value>60</param-value>
</init-param>
<init-param>
<param-name>scope</param-name>
<param-value>session</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CacheFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
上面定義將緩存所有.jsp頁面,緩存刷新時間爲60秒,緩存作用域爲Session
注意,CacheFilter只捕獲Http頭爲200的頁面請求,即只對無錯誤請求作緩存,
而不對其他請求(如500,404,400)作緩存處理
下面轉自http://www.blogjava.net/ruchal/archive/2009/05/31/277420.html?opt=admin
三、標籤參數介紹
使用了oscache:cache 的屬性:
key 緩衝的key,可以是任何的字符串,也可以動態生成。在一個範圍內必須唯一。默認使用請求的URI和請求的字符串(問號後面的部分)
scope 範圍,有application和session, 默認爲 application
time 緩衝內容的時間(秒),默認爲1小時,3600秒,如果爲-1則內容永遠不過期
refresh 強制刷新緩存,false 或者true,可以使用此屬性受動刷新需立即更新的數據
groups 設置分組,可以同組的緩衝數據進行控制
language 語言,默認爲當前頁面的語言
還有許多其他的屬性,在這裏不一一列舉
四、oscache 基本用法
1,設置緩存
<%@ taglib uri="/WEB-INF/tlds/oscache.tld" prefix="oscache" %>
<oscache:cache key=”cacheKey” time=”300” scope=”application”>被緩存的列表 </oscache:cache> 其中,cacheKey和time可以自己動態構件,scope(緩存範圍) 可以是ession、application
注意:cacheKey或者time如果是jsp表達式時,如:key=”<%=”string”+variable%>”而不是:key=”string<%=variable%>”,寫法要注意,否則頁面會報錯
2,刷新緩存
<%@ taglib uri="/WEB-INF/tlds/oscache.tld" prefix="oscache" %>
<oscache:flush key=”cacheKey” scope=”application” />
3,分組緩存
<cache:flush group='b' scope='application'/>
<cache:cachekey='cacheKey_1' groups='a,b' duration='5s'>
這裏面的內容被緩存到鍵值爲cacheKey_1,組名爲a和b的緩存中,正常情況下,每隔5秒鐘刷新一 次,但受上面標籤“<cache:flush group='b' scope='application'/>”的影響,它將隨每次頁面的刷新而刷新
</cache:cache>
<cache:cachekey='cacheKey_2' groups='a' duration='5s'>
這裏面的內容被緩存到鍵值爲cacheKey_2,組名爲a的緩存中,它將每隔5秒中刷新一次
</cache:cache>
<cache:cachekey='cacheKey_3' duration='20s'>
這裏面的內容被緩存到cacheKey_3,組a,b中,組是通過標籤<cache: addgroup>而添加的,它也會受本頁開頭標籤“<cache:flush group='b' scope='application'/>”的影響而隨頁面刷新而刷新
<cache:addgroup group='a'/>
<cache:addgroup group='b'/>
</cache:cache>
<cache:cachekey='cacheKey_4' duration='20s'>
這裏面的內容被緩存到cacheKey_4,組a,b中,組是通過標籤<cache: addgroups>而添加的,它也會受本頁開頭標籤“<cache:flush group='b' scope='application'/>”的影響而隨頁面刷新而刷新
<cache:addgroups groups='a,b'/>
</cache:cache>