捕風之巢

          統計

          留言簿(3)

          java友情鏈接

          閱讀排行榜

          評論排行榜

          OSCache使用指南

          ?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_APPLICATIONWEB-INFliboscache.jar
          $WEB_APPLICATIONWEB-INFclassesoscache.properties
          $WEB_APPLICATIONWEB-INFclassesoscache.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)作緩存處理


          OSCache簡介


          OSCache是OpenSymphony組織提供的一個J2EE架構中Web應用層的緩存技術實現組件,它的出現解決了我們面臨的問題。 OSCache
          目前最新的穩定版本是2.0,本文中的例子都是基于這個版本的,如果大家運行例子的過程中發生問題,請首先確認是否采用了正確的軟件版本。

          2.1 主要特征


          1. 兼容多種支持JSP的web服務器

          已經通過兼容測試的web服務器包括OrionServer (1.4.0或者以上版本) 、Macromedia JRun (3.0或者以上版本) 、BEA Weblogic (7.x或者以上版本) 、IBM Websphere (5.0版本)、Silverstream (3.7.4版本)、Caucho Resin (1.2.3或者以上版本)、Tomcat (4.0或者以上版本) ,其他支持servlet2.3、jsp1.2的web服務器應該都是完全兼容
          OSCache
          的。

          2. 可選的緩存區

          你可以使用內存、硬盤空間、同時使用內存和硬盤或者提供自己的其他資源(需要自己提供適配器)作為緩存區。

          使用內存作為緩存區將可以提供更好的性能
          使用硬盤作為緩存區可以在服務器重起后迅速恢復緩存內容
          同時使用內存和硬盤作為緩存區則可以減少對內存的占用
          3. 靈活的緩存系統

          OSCache
          支持對部分頁面內容或者對頁面級的響應內容進行緩存,編程者可以根據不同的需求、不同的環境選擇不同的緩存級別。

          4. 容錯

          在一般的web應用中,如果某個頁面需要和數據庫打交道,而當客戶請求到達時,web應用和數據庫之間無法進行交互,那么將返回給用戶"系統出錯"或者類似的提示信息,如果使用了
          OSCache
          的話,你可以使用緩存提供給用戶,給自己贏得維護系統或者采取其他補救的時間。

          其它特性還包括對集群的支持、緩存主動刷新等特性,大家可以參考OpenSymphony網站上的其他資源獲取更多的信息。

          3
          OSCache
          組件的安裝


          OSCache
          是一個基于web應用的組件,他的安裝工作主要是對web應用進行配置,大概的步驟如下:

          1. 下載、解壓縮
          OSCache


          請到
          OSCache的主頁http://www.opensymphony.com/oscache/download.html下載Oscache的最新版本,作者下載的是OSCache
          的最新穩定版本2.0。

          將下載后的。Zip文件解壓縮到c:\
          oscache(后面的章節中將使用%OSCache
          _Home%來表示這個目錄)目錄下

          2. 新建立一個web應用

          3. 將主要組件%
          OSCache_Home%\oscache
          .jar放入WEB-INF\lib目錄

          4. commons-logging.jar、commons-collections.jar的處理

          OSCache組件用Jakarta Commons Logging來處理日志信息,所以需要commons-logging.jar的支持,請將%OSCache
          _Home%\lib\core\commons-logging.jar放入classpath(通常意味著將這個文件放入WEB-INF\lib目錄)
          如果使用JDK1.3,請將%
          OSCache
          _Home%\lib\core\commons-collections.jar放入classpath,如果使用JDK1.4或者以上版本,則不需要了
          5. 將
          oscache.properties、oscache
          .tld放入WEB-INF\class目錄

          %
          OSCache_Home%\oscache.properties包含了對OSCache
          運行特征值的設置信息
          %
          OSCache_Home%\oscache.tld包含了OSCache
          提供的標簽庫的定義內容
          6. 修改web.xml文件

          在web.xml文件中增加下面的內容,增加對
          OSCache
          提供的taglib的支持:

          <taglib>
          <taglib-uri>
          oscache
          </taglib-uri>
          <taglib-location>/WEB-INF/classes/
          oscache
          .tld</taglib-location>
          </taglib>




          4 開始使用
          OSCache
          中的緩存組件


          OSCache
          中按照緩存范圍的不同分為兩種不同的方式:一種是緩存JSP頁面中部分或者全部內容,一種是基于整個頁面文件的緩存。

          4.1 JSP部分內容緩存


          4.1.1 Cache-
          OSCache
          提供的緩存標簽


          這是
          OSCache
          提供的標簽庫中最重要的一個標簽,包括在標簽中的內容將應用緩存機制進行處理,處理的方式將取決于編程者對cache標簽屬性的設置。

          第一次請求到達時,標簽中的內容被處理并且緩存起來,當下一個請求到達時,緩存系統會檢查這部分內容的緩存是否已經失效,主要是以下幾項:

          1. 緩存時間超過了cache標簽設置的time或者duration屬性規定的超時時間
          2. cron屬性規定的時間比緩存信息的開始時間更晚
          3. 標簽中緩存的內容在緩存后又被重新刷新過
          4. 其他緩存超期設定
          如果符合上面四項中的任何一項,被緩存的內容視為已經失效,這時被緩存的內容將被重新處理并且返回處理過后的信息,如果被緩存的內容沒有失效,那么返回給用戶的將是緩存中的信息。

          cache標簽的屬性說明:

          key - 標識緩存內容的關鍵詞。在指定的作用范圍內必須是唯一的。默認的key是被訪問頁面的URI和后面的請求字符串。

          你可以在同一個頁面中使用很多cache標簽而不指定他的key屬性,這種情況下系統使用該頁面的URI和后面的請求字符串,另外再自動給這些key增加一個索引值來區分這些緩存內容。但是不推薦采用這樣的方式。

          scope - 緩存發生作用的范圍,可以是application或者session

          time - 緩存內容的時間段,單位是秒,默認是3600秒,也就是一個小時,如果設定一個負值,那么這部分被緩存的內容將永遠不過期。

          duration - 指定緩存內容失效的時間,是相對time的另一個選擇,可以使用簡單日期格式或者符合USO-8601的日期格式。如:duration='PT5M' duration='5s'等

          refresh - false 或者true。

          如果refresh屬性設置為true,不管其他的屬性是否符合條件,這部分被緩存的內容都將被更新,這給編程者一種選擇,決定什么時候必須刷新。

          mode - 如果編程者不希望被緩存的內容增加到給用戶的響應中,可以設置mode屬性為"silent"

          其它可用的屬性還包括:cron 、groups、language、refreshpolicyclass、refreshpolicyparam。

          上面的這些屬性可以單獨使用,也可以根據需要組合使用,下面的例子將講解這些常用屬性的使用方式。

          4.1.2 Cache標簽實例分析:


          1. 最簡單的cache標簽用法

          使用默認的關鍵字來標識cache內容,超時時間是默認的3600秒

          <cache:cache>
          <%
          //自己的JSP代碼內容
          %>
          </cache:cache>




          2. 用自己指定的字符串標識緩存內容,并且設定作用范圍為session。

          <cache:cache key="foobar" scope="session">
          <%
          //自己的JSP代碼內容
          %>
          </cache:cache>
          3.動態設定key值,使用自己指定的time屬性設定緩存內容的超時時間,使用動態refresh值決定是否強制內容刷新。

          因為
          OSCache
          使用key值來標識緩存內容,使用相同的key值將會被認為使用相同的的緩存內容,所以使用動態的key值可以自由的根據不同的角色、不同的要求決定使用不同的緩存內容。

          <cache:cache key="<%= product.getId() %>" time="1800" refresh="<%= needRefresh %>">
          <%
          //自己的JSP代碼內容
          %>
          </cache:cache>




          4. 設置time屬性為負數使緩存內容永不過期

          <cache:cache time="-1">
          <%
          //自己的JSP代碼內容
          %>




          5. 使用duration屬性設置超期時間

          <cache:cache duration='PT5M'>
          <%
          //自己的JSP代碼內容
          %>




          6. 使用mode屬性使被緩存的內容不加入給客戶的響應中

          <cache:cache mode='silent'>
          <%
          //自己的JSP代碼內容
          %>




          4.2 用CashFilter實現頁面級緩存


          OSCache
          組件中提供了一個CacheFilter用于實現頁面級的緩存,主要用于對web應用中的某些動態頁面進行緩存,尤其是那些需要生成pdf格式文件/報表、圖片文件等的頁面,不僅減少了數據庫的交互、減少數據庫服務器的壓力,而且對于減少web服務器的性能消耗有很顯著的效果。

          這種功能的實現是通過在web.xml中進行配置來決定緩存哪一個或者一組頁面,而且還可以設置緩存的相關屬性,這種基于配置文件的實現方式對于J2EE來說應該是一種標準的實現方式了。

          [注] 只有客戶訪問時返回http頭信息中代碼為200(也就是訪問已經成功)的頁面信息才能夠被緩存

          1. 緩存單個文件

          修改web.xml,增加如下內容,確定對/testContent.jsp頁面進行緩存。

          <filter>
          <filter-name>CacheFilter</filter-name>
          <filter-class>com.opensymphony.
          oscache
          .web.filter.CacheFilter</filter-class>
          </filter>
          <filter-mapping>
          <filter-name>CacheFilter</filter-name>
          <!-對/testContent.jsp頁面內容進行緩存-->
          <url-pattern>/testContent.jsp</url-pattern>
          </filter-mapping>




          2. 緩存URL pattern

          修改web.xml,增加如下內容,確定對*.jsp頁面進行緩存。

          <filter>
          <filter-name>CacheFilter</filter-name>
          <filter-class>com.opensymphony.
          oscache
          .web.filter.CacheFilter</filter-class>
          </filter>
          <filter-mapping>
          <filter-name>CacheFilter</filter-name>
          <!-對所有jsp頁面內容進行緩存-->
          <url-pattern>*.jsp</url-pattern>
          </filter-mapping>




          3. 自己設定緩存屬性

          在頁面級緩存的情況下,可以通過設置CacheFilter的初始屬性來決定緩存的一些特性:time屬性設置緩存的時間段,默認為3600秒,可以根據自己的需要只有的設置,而scope屬性設置,默認為application,可選項包括application、session

          <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>600</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>
          <!-對所有jsp頁面內容進行緩存-->
          <url-pattern>*.jsp</url-pattern>
          </filter-mapping>



          posted on 2006-10-11 09:37 捕風 閱讀(452) 評論(0)  編輯  收藏 所屬分類: java高級

          主站蜘蛛池模板: 高淳县| 鸡西市| 尉犁县| 虞城县| 和平区| 志丹县| 盖州市| 吉安县| 安陆市| 城口县| 佛山市| 青冈县| 凤台县| 灵寿县| 盐津县| 辽阳县| 洛南县| 虹口区| 水富县| 抚松县| 额敏县| 舒城县| 沅江市| 昭苏县| 瑞昌市| 英山县| 天水市| 泗阳县| 西畴县| 福海县| 股票| 长宁县| 兴仁县| 西吉县| 白银市| 麦盖提县| 改则县| 南江县| 万安县| 苍南县| 黔西|