一、Cache介紹
Cache是一種用于提高系統(tǒng)響應(yīng)速度、改善系統(tǒng)運(yùn)行性能的技術(shù)。尤其是在Web應(yīng)用中,通過(guò)緩存頁(yè)面的輸出結(jié)果,可以很顯著的改善系統(tǒng)運(yùn)行性能。
例如:電子商務(wù)中關(guān)于送貨區(qū)域,統(tǒng)計(jì)報(bào)表
1.1 問(wèn)題的共同點(diǎn)
1、被處理的內(nèi)容短時(shí)間不變,所以短時(shí)間內(nèi)可以作為靜態(tài)內(nèi)容進(jìn)行處理
2、在一個(gè)不太長(zhǎng)的時(shí)間內(nèi),被處理內(nèi)容可能或者必定產(chǎn)生變化,所以必須將他們作為動(dòng)態(tài)內(nèi)容進(jìn)行處理
3、在合理的時(shí)間區(qū)段內(nèi)可以忽略被處理內(nèi)容變化后帶來(lái)的影響
4、對(duì)這些內(nèi)容的處理動(dòng)作比較消耗系統(tǒng)性能,影響系統(tǒng)響應(yīng)時(shí)間
1.2 解決方法
1、緩存信息
??????當(dāng)上述的基礎(chǔ)數(shù)據(jù)或者統(tǒng)計(jì)報(bào)表第一次被訪問(wèn)時(shí),被處理的內(nèi)容被當(dāng)作動(dòng)態(tài)信息,基礎(chǔ)數(shù)庫(kù)從數(shù)據(jù)庫(kù)中獲得,統(tǒng)計(jì)報(bào)表也會(huì)被生成符合要求的圖形、文件,然后這些信息都會(huì)被放入緩存信息中。
2、響應(yīng)信息由緩存提供
??????當(dāng)上述的基礎(chǔ)數(shù)據(jù)或者統(tǒng)計(jì)報(bào)表繼續(xù)被訪問(wèn)時(shí),系統(tǒng)將會(huì)首先檢查緩存信息中是否有對(duì)應(yīng)的內(nèi)容和我們?cè)O(shè)定的緩存規(guī)則,如果符合緩存信息存在而且符合緩存規(guī)則,給出的響應(yīng)將來(lái)自于緩存信息,如果沒(méi)有或者緩存信息已經(jīng)不符合設(shè)定的要求,系統(tǒng)將重復(fù)上一步的動(dòng)作。
很顯然,上面的步驟2中,多數(shù)情況下,當(dāng)用戶請(qǐng)求到達(dá)時(shí),被處理的內(nèi)容將來(lái)自于緩存,所以大大的減少了與數(shù)據(jù)庫(kù)的交互,或者不再需要為每個(gè)請(qǐng)求都生成一次報(bào)表圖形或者文件,這部分工作的減少對(duì)于降低系統(tǒng)性能消耗、提高系統(tǒng)穩(wěn)定性和并發(fā)處理能力是非常有益的。
?
二、OSCache介紹
OSCache中按照緩存范圍的不同分為兩種不同的方式:一種是緩存JSP頁(yè)面中部分或者全部?jī)?nèi)容,一種是基于整個(gè)頁(yè)面文件的緩存。
2.1 Cache-OSCache提供的緩存JSP頁(yè)面中部分或者全部?jī)?nèi)容標(biāo)簽
這是OSCache提供的標(biāo)簽庫(kù)中最重要的一個(gè)標(biāo)簽,包括在標(biāo)簽中的內(nèi)容將應(yīng)用緩存機(jī)制進(jìn)行處理,處理的方式將取決于編程者對(duì)cache標(biāo)簽屬性的設(shè)置。
第一次請(qǐng)求到達(dá)時(shí),標(biāo)簽中的內(nèi)容被處理并且緩存起來(lái),當(dāng)下一個(gè)請(qǐng)求到達(dá)時(shí),緩存系統(tǒng)會(huì)檢查這部分內(nèi)容的緩存是否已經(jīng)失效,主要是以下幾項(xiàng):
1. 緩存時(shí)間超過(guò)了cache標(biāo)簽設(shè)置的time或者duration屬性規(guī)定的超時(shí)時(shí)間
2. cron屬性規(guī)定的時(shí)間比緩存信息的開(kāi)始時(shí)間更晚
3. 標(biāo)簽中緩存的內(nèi)容在緩存后又被重新刷新過(guò)
4. 其他緩存超期設(shè)定
如果符合上面四項(xiàng)中的任何一項(xiàng),被緩存的內(nèi)容視為已經(jīng)失效,這時(shí)被緩存的內(nèi)容將被重新處理并且返回處理過(guò)后的信息,如果被緩存的內(nèi)容沒(méi)有失效,那么返回給用戶的將是緩存中的信息。
cache標(biāo)簽的屬性說(shuō)明:
key - 標(biāo)識(shí)緩存內(nèi)容的關(guān)鍵詞。在指定的作用范圍內(nèi)必須是唯一的。默認(rèn)的key是被訪問(wèn)頁(yè)面的URI和后面的請(qǐng)求字符串。 你可以在同一個(gè)頁(yè)面中使用很多cache標(biāo)簽而不指定他的key屬性,這種情況下系統(tǒng)使用該頁(yè)面的URI和后面的請(qǐng)求字符串,另外再自動(dòng)給這些key增加一個(gè)索引值來(lái)區(qū)分這些緩存內(nèi)容。但是不推薦采用這樣的方式。
scope - 緩存發(fā)生作用的范圍,可以是application或者session
time - 緩存內(nèi)容的時(shí)間段,單位是秒,默認(rèn)是3600秒,也就是一個(gè)小時(shí),如果設(shè)定一個(gè)負(fù)值,那么這部分被緩存的內(nèi)容將永遠(yuǎn)不過(guò)期。
duration - 指定緩存內(nèi)容失效的時(shí)間,是相對(duì)time的另一個(gè)選擇,可以使用簡(jiǎn)單日期格式或符合USO-8601的日期格式。如:duration='PT5M' duration='5s'等
refresh - false 或者true。如果refresh屬性設(shè)置為true,不管其他的屬性是否符合條件,這部分被緩存的內(nèi)容都將被更新,這給編程者一種選擇,決定什么時(shí)候必須刷新。
mode - 如果編程者不希望被緩存的內(nèi)容增加到給用戶的響應(yīng)中,可以設(shè)置mode屬性為"silent"
cron- Cron表達(dá)式包括5個(gè)字段分別為Minute,Hour,DOM(Day Of Month),Month,DOW(Day Of Week)。
?????他們順序地對(duì)應(yīng)了5個(gè)位置。當(dāng)某個(gè)位置上的值為*時(shí),表示該位置上的任意時(shí)間。
???????另外還提供了指定時(shí)間的操作符號(hào)"-",",","/",他們分別表示一段時(shí)間范圍,具體的時(shí)間,以及遞增的時(shí)間段。
???????下面是幾個(gè)例子說(shuō)明一下Cron表達(dá)式的基本應(yīng)用,有興趣的也可以查看下OSCache的文檔。
???????? 第30分鐘,第50分鐘緩存內(nèi)容失效。
其它可用的屬性還包括:groups、language、refreshpolicyclass、refreshpolicyparam。
上面的這些屬性可以單獨(dú)使用,也可以根據(jù)需要組合使用,下面的例子將講解這些常用屬性的使用方式。
2.2 用CashFilter實(shí)現(xiàn)頁(yè)面級(jí)緩存
在OSCache組件中提供了一個(gè)CacheFilter用于實(shí)現(xiàn)頁(yè)面級(jí)的緩存,主要用于對(duì)web應(yīng)用中的某些動(dòng)態(tài)頁(yè)面進(jìn)行緩存,尤其是那些需要生成pdf格式文件/報(bào)表、圖片文件等的頁(yè)面,不僅減少了數(shù)據(jù)庫(kù)的交互、減少數(shù)據(jù)庫(kù)服務(wù)器的壓力,而且對(duì)于減少web服務(wù)器的性能消耗有很顯著的效果。
這種功能的實(shí)現(xiàn)是通過(guò)在web.xml中進(jìn)行配置來(lái)決定緩存哪一個(gè)或者一組頁(yè)面,而且還可以設(shè)置緩存的相關(guān)屬性,這種基于配置文件的實(shí)現(xiàn)方式對(duì)于J2EE來(lái)說(shuō)應(yīng)該是一種標(biāo)準(zhǔn)的實(shí)現(xiàn)方式了。
<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> <!-對(duì)/testContent.jsp頁(yè)面內(nèi)容進(jìn)行緩存--> <url-pattern>/testContent.jsp</url-pattern>
<!-對(duì)所有jsp頁(yè)面內(nèi)容進(jìn)行緩存--> <url-pattern>*.jsp</url-pattern> </filter-mapping>
參考:
1. 應(yīng)用OSCache提升J2EE系統(tǒng)運(yùn)行性能
2、oscache源代碼