轉載自 http://www.javaeye.com/topic/172186
作者 thblovezhj
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)作緩衝處理