一概述
在Web應用中有些報表的生成可能需要數據庫花很長時間才能計算出來有的網站提供天氣信息它需要訪問遠程服務器進行SOAP調用才能得到溫度信息所有這一切都屬於復雜信息的例子在Web頁面中加入過多的復雜信息可能導致Web服務器數據庫服務器負荷過重JSP代碼塊緩沖為開發者帶來了隨意地增加各種復雜信息的自由
JSP能夠在標記庫內封裝和運行復雜的Java代碼它使得JSP頁面文件更容易維護使得非專業開發人員使用JSP頁面文件更加方便現在已經有許多標記庫它們或者是商業產品或者是源代碼開放產品但這些產品中的大多數都只是用標記庫的形式實現原本可以用一個簡單的Java Scriptlet實現的功能很少有產品以某種創造性的方式使用定制標記提供在出現JSP定制標記庫之前幾乎不可能實現的用法
OSCache標記庫由OpenSymphony設計它是一種開創性的JSP定制標記應用提供了在現有JSP頁面之內實現快速內存緩沖的功能雖然已經有一些供應商在提供各種形式的緩存產品但是它們都屬於面向特定供應商的產品OSCache能夠在任何JSP 兼容的服務器上運行它不僅能夠為所有用戶緩沖現有JSP代碼塊而且能夠以用戶為單位進行緩沖OSCache還包含一些提高可伸縮性的高級特性比如緩沖到磁盤可編程的緩沖刷新異常控制等等另外正如OpenSymphony的其他產品OSCache的代碼也在一個開放源代碼許可協議之下免費發行
本文以一個假想的拍賣網站設計過程為例介紹OSCache的工作過程這個假想的Web網站將包含一個報告最近拍賣活動的管理頁面一個功能完整帶有各種宣傳信息的主頁一個特殊的導航條它包含了用戶所有尚未成交的拍賣活動信息
二管理頁面
拍賣網站包含一個管理報表數據庫服務器需要數秒時間才能創建這樣一個報表報表生成時間長這一點很重要因為我們可能讓多個管理員監視系統運行情況同時又想避免管理員每次訪問時都重新生成這個報表為了實現這一點我們將把整個頁面封裝到一個應用級的緩沖標記之內這個緩沖標記每隔小時刷新其他供應商提供的一些產品也具有類似的功能只是OSCache比它們做得更好
為簡單計我們將不過多地關注格式問題在編寫管理頁面時我們首先把標記庫聲明加入到頁面
<%@ taglib uri=cachetags prefix=cache %>
接下來我們要用cache標記來包圍整個頁面cache標記的默認緩沖時間是小時
<cache:cache> 復雜的管理報表 </cache:cache>
現在管理頁面已經被緩沖如果管理員在頁面生成後的一個小時之內再次訪問同一頁面他看到的將是以前緩存的頁面不需要由數據庫服務器再次生成這個報表
三主頁
拍賣網站的主頁顯示網站活動情況宣傳那些即將結束的拍賣活動我們希望顯示出正在進行的拍賣活動數量當前登錄用戶數量在短期內就要結束的拍賣活動的清單以及當前時間這些信息有著不同的時間精確度要求網站上的拍賣活動通常持續數天因此我們可以把緩沖有效拍賣活動數量的時間定為個小時用戶數量的變化顯然要頻繁一些但這裡我們將把這個數值每次緩沖分鐘最後我們希望頁面中顯示的當前時間總是精確的頁面訪問時間
在主頁中聲明標記庫之後我們首先以不帶緩沖的方式直接輸出當前日期
現在是<%=new javautilDate()%>
接下來我們要顯示一個清單列出那些將在短期內結束的拍賣活動
<cache:cache> <ul> <% // 構造一個包含最近拍賣活動的Iterator Iterator auctions = while (auctionshasMore()) { Auction auction = (Auction)auctionsnext(); %><li><%=auction%></li%< } %> </ul> </cache:cache>
最後我們希望顯示出正在進行的拍賣活動的數量這個數字需要緩沖小時由於cache標記需要的是緩沖數據的秒數我們把小時轉換成秒
<cache:cache time=> <% //查詢數據庫得到拍賣活動總數 int auctionCount = %> 本網站正在進行的拍賣活動有<%=auctionCount%>個! </cache>
可以看到我們只用少量的代碼就構造出了一個帶有復雜緩沖系統的主頁這個緩沖系統對頁面各個部分分別進行緩沖而且各個部分的緩沖時間完全符合它們各自的信息變化頻繁程度由於有了緩沖現在我們可以在主頁中放入更多的內容而在以前沒有緩沖的情況下主頁中放入過多的內容會導致頁面訪問速度變慢甚至可能給數據庫服務器帶來過重的負載
四導航條
假設在規劃網站的時候我們決定在左邊導航條的下方顯示購物車內容我們將顯示出用戶所拍賣的每一種商品的出價次數和當前報價以及所有那些當前用戶出價最高的商品的清單
我們利用會話級的緩沖能力在導航條中構造上述功能把下面的代碼放入模板或者包含文件以便網站中的其他頁面引用這個導航條
<cache:cache key=navbar scope=session time=> <% //提取並顯示當前的出價信息 %> </cache:cache>
在這裡我們引入了兩個重要的屬性即key和scope在本文前面的代碼中由於cache標記能夠自動為代碼塊創建唯一的key所以我們不需要手工設置這個key屬性但在這裡我們想要從網站的其余部分引用這個被緩沖的代碼塊因此我們顯式定義了該cache標記的key屬性第二scope屬性用來告訴cache標記當前代碼塊必須以用戶為單位緩沖而不是為所有用戶緩沖一次
在使用會話級緩沖時應該非常小心應該清楚雖然我們可以讓復雜的導航條減少倍或倍的服務器負載但它將極大地增加每個會話所需要的內存空間在CPU能力方面增加可能的並發用戶數量無疑很理想但是一旦在內存支持能力方面讓並發用戶數量降低到了CPU的限制之下這個方案就不再理想
正如本文前面所提到的我們希望從網站的其余部分引用這個緩沖的代碼塊這是因為當一個用戶增加了一個供拍賣的商品或者出價競購其他用戶拍賣的商品時我們希望刷新緩沖使得導航條下一次被讀取時具有最新的內容雖然這些數據可能因為其他用戶的活動而改變但如果用戶在網站上執行某個動作之後看到自己的清單仍未改變他可能會感到非常困惑
OSCache庫提供的flush標記能夠刷新緩沖內容我們可以把下面的代碼加入到處理用戶動作且可能影響這一區域的頁面之中
<cache:flush key=navbar scope=session />
當用戶下次訪問它時navbar緩沖塊將被刷新
至此為止我們這個示例網站的構造工作已經完成且可以開始運行下面我們來看看OSCache的異常處理能力即使緩沖的內容已經作廢比如在緩沖塊內出現了Java異常OSCache標記庫仍舊允許我們用編程的方法顯示這些內容有了這種異常控制功能我們可以拆除數據庫服務器和Web服務器之間的連接而網站仍能夠繼續運行JSP 規范引入了TryCatchFinally接口這個接口允許標記本身檢測和處理Java異常因此標記可以結合這種異常處理代碼使得JSP頁面更簡單更富有條理
OpenSymphony正在計劃實現其他的緩沖機制以及一個可管理性更好的主系統它將使我們能夠對緩沖使用的RAM和磁盤空間進行管理一旦有了這些功能我們就能夠進一步提高網站的響應速度和可靠性
【結束語】
OSCache能夠幫助我們構造出更豐富多彩具有更高性能的網站有了OSCache標記庫的幫助現在我們能夠用它解決一些影響網站響應能力的問題比如訪問量高峰期數據庫服務器負荷過重等
From:http://tw.wingwit.com/Article/program/Java/JSP/201311/20726.html