ASP.NET2.0緩存(Cache)技術(shù)深入理解
數(shù)據(jù)緩存(DataCaching)就是將數(shù)據(jù)暫存于內(nèi)存緩存區(qū)中(有時(shí)也暫存于硬盤(pán)緩存區(qū)中)的一種技術(shù).當(dāng)數(shù)據(jù)本身改變得不怎么頻繁,而被訪問(wèn)的頻率又比較高時(shí),采用這種技術(shù)將大大提高警惕數(shù)據(jù)訪問(wèn)的效率.
1.網(wǎng)頁(yè)輸出緩存
(1)加顯緩存
<%@OutputCacheDuration="60"VaryByParam=none%>
語(yǔ)句<%@%>是網(wǎng)頁(yè)配置的指令,在這里用來(lái)給網(wǎng)頁(yè)指定緩存參數(shù).其中:Duration="60"代表緩存持續(xù)時(shí)間為60秒,VaryByParam屬性用來(lái)指定特定版本的網(wǎng)頁(yè)輸出,因哪個(gè)參數(shù)而改變.在<%@OutputCache%>配置指令中一定要加入VaryByParam屬性.即使不使用這個(gè)版本屬性,也要將它加入,但將其值設(shè)為none.
(2)回調(diào)緩存
<%@OutputCacheDuration=60VaryByParam=stata%>
根據(jù)lll.aspx?stata=的內(nèi)容分別緩存
下面的方法可以根據(jù)內(nèi)容刷新
<scriptrunat="server">
SharedFunctionGetCurrentDate(ByValcontextAsHttpContext)AsString
ReturnNow.ToString()
EndFunction
</script>
<asp:SubstitutionID="Substitution1"runat="server"MethodName="GetCurrentDate"/>
2.數(shù)據(jù)庫(kù)緩存
在ASP.NET2.0中可以通過(guò)數(shù)據(jù)源設(shè)置數(shù)據(jù)表的緩存參數(shù).在SqlDataSource控件的屬性中有幾項(xiàng)用于設(shè)置緩存的參數(shù).
CacheDuration:代表緩存的持續(xù)時(shí)間.默認(rèn)為Infinite(無(wú)限)
CacheExpirationPolicy:緩存的策略.包括兩種設(shè)置:Absolute和Sliding.當(dāng)設(shè)置成前者時(shí),時(shí)限一到緩存區(qū)失效;當(dāng)設(shè)置為后者時(shí),時(shí)限到立即刷新緩存區(qū)中的數(shù)據(jù),并繼續(xù)緩存更新后的數(shù)據(jù).
CacheKeyDependency:可以用于SQLServer2005數(shù)據(jù)庫(kù).
EnableCaching:默認(rèn)時(shí)為False,即不使用數(shù)據(jù)緩存,將該屬性改為T(mén)rue時(shí)即可啟動(dòng)數(shù)據(jù)緩存.
SqlCacheDependecy:緩存依賴關(guān)系.例如設(shè)置為pubs:authors表示數(shù)據(jù)庫(kù)Pubs中的authors數(shù)據(jù)表與它的數(shù)據(jù)緩存之間建立依賴關(guān)系.
有時(shí)數(shù)據(jù)表太大,緩存區(qū)可能會(huì)占用太大的內(nèi)存空間.可以將數(shù)據(jù)緩存到硬盤(pán)的緩存區(qū)中,為了實(shí)現(xiàn)這一點(diǎn),需要做一些專門(mén)的設(shè)置.設(shè)置包括兩方面.
一:在網(wǎng)頁(yè)中配置<%@OutputCacheDuration="3600"VaryByParam="none"DiskCacheable="true"%>
二:在Web.config文件中指定硬盤(pán)緩區(qū)區(qū)的大小,配置的語(yǔ)句如下:
<system.web>
<caching>
<outputCache>
<diskCacheEnabled="true"maxSizePerApp="2"/>
</outputCache>
</caching>
</system.web>
其中diskCacheEnabled="true"用來(lái)啟動(dòng)硬盤(pán)緩存功能;maxSizePerApp="2"用來(lái)確定緩存區(qū)的容量,這里確定的緩存區(qū)最大容量為2M.同于對(duì)硬盤(pán)的存取速度比較慢,因此硬盤(pán)緩存只適用于緩存持續(xù)時(shí)間較長(zhǎng)的情況(本例中緩存時(shí)間為1小時(shí)).
3.緩存池
數(shù)據(jù)緩存技術(shù)大大提高警惕了數(shù)據(jù)訪問(wèn)的速度,但卻可能引發(fā)數(shù)據(jù)不一致的問(wèn)題.因此以上緩存技術(shù)只適用于數(shù)據(jù)量大,變化頻率不高的數(shù)據(jù).現(xiàn)在ASP.NET2.0新版本結(jié)合數(shù)據(jù)庫(kù)SQLServer2005,對(duì)數(shù)據(jù)緩存功能又做了很大的改進(jìn),既簡(jiǎn)化了使用過(guò)程,又完善了處理措施,其中最突出的一點(diǎn)就是與數(shù)據(jù)庫(kù)相結(jié)合自動(dòng)解決了數(shù)據(jù)失效問(wèn)題.
在ASP.NET2.0中為了解決數(shù)據(jù)失效問(wèn)題,通過(guò)新類SQLCacheDependency建立起與新一代數(shù)據(jù)庫(kù)的"SQL緩存依賴關(guān)系(SQLExpressdependencycaching)",這種關(guān)系可以使得數(shù)據(jù)庫(kù)能夠自動(dòng)監(jiān)視數(shù)據(jù)表的狀況,一旦數(shù)據(jù)表發(fā)生了變化,立即啟動(dòng)數(shù)據(jù)庫(kù)本身的觸發(fā)器將相應(yīng)的緩存區(qū)中的數(shù)據(jù)變?yōu)闊o(wú)效.
此方法也可用于SQL7/2000數(shù)據(jù)庫(kù),但是使用關(guān)必須先配置所監(jiān)視的數(shù)據(jù)庫(kù).配置方法比較麻煩,但配置后使用起來(lái)還是很簡(jiǎn)單的.對(duì)于更早期版本的SQLServer或者其他類型的數(shù)據(jù)庫(kù)(例如Oracle),則不能利用這一功能.
配置數(shù)據(jù)庫(kù)連接池
C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727>aspnet_regsql.exe
運(yùn)行asp.netsqlServer配置向?qū)?
Aspnet_regsql.exe–S“\DBNAME”–E–d“pubs”–ed
-Ewindows授權(quán)
–ed為enabled
Aspnet_regsql.exe–S“\DBNAME”–E–D“pubs”–et–t“authors”
當(dāng)pubs.authors改變時(shí)改變緩存
<%@OutputCacheDuration="9999999"VaryByParam="none"SqlDependency="pubs.authors"%>
緩存配置
<caching>
<outputCache>
<diskCacheenabled="true"maxSizePerApp="2"/>
</outputCache>
<outputCacheSettings>
<outputCacheProfiles>
<addname="CacheFor60Seconds"duration="60"/>
</outputCacheProfiles>
</outputCacheSettings>
<!--
<sqlCacheDependencyenabled="true"pollTime="1000">
<databases>
<addname="PubsDB"connectionStringName="pubsConnectionString"/>
</databases>
</sqlCacheDependency>
-->
</caching>
相關(guān)文章
.NET 6開(kāi)發(fā)TodoList應(yīng)用之實(shí)現(xiàn)查詢分頁(yè)
這篇文章介紹了.NET 6開(kāi)發(fā)TodoList應(yīng)用之實(shí)現(xiàn)查詢分頁(yè),文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01ASP.NET Core中預(yù)壓縮靜態(tài)文件的方法步驟
這篇文章主要給大家介紹了關(guān)于ASP.NET Core中如何預(yù)壓縮靜態(tài)文件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03實(shí)現(xiàn)onmouseover和onmouseout應(yīng)用于RadioButtonList或CheckBoxList控件上
一直想實(shí)現(xiàn)onmouseover和onmouseout應(yīng)用于RadioButtonList或CheckBoxList控件上。此功能就是當(dāng)鼠標(biāo)經(jīng)過(guò)時(shí)RadioButtonList或CheckBoxList每一個(gè)Item時(shí),讓Item有特效顯示,離開(kāi)時(shí),恢復(fù)原樣有演示動(dòng)畫(huà),感興趣的朋友可以了解下啊2013-01-01ASP.NET之Response.Cookies.Remove 無(wú)法刪除COOKIE的原因
在web開(kāi)發(fā)中Cookie是必不可少的,.NET自然也有一個(gè)強(qiáng)大的Cookie操作類,我們用起來(lái)也非常方便,不過(guò)在使用中我們會(huì)發(fā)現(xiàn)一個(gè)坑爹的事情Response.Cookies.Remove刪除不了Cookie。2013-06-06.NET使用YARP通過(guò)編碼方式配置域名轉(zhuǎn)發(fā)實(shí)現(xiàn)反向代理
這篇文章介紹了.NET使用YARP通過(guò)編碼方式配置域名轉(zhuǎn)發(fā)實(shí)現(xiàn)反向代理的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09asp.net Context.Handler 頁(yè)面間傳值方法
很有用的頁(yè)面間傳值方法(Context.Handler),使用說(shuō)明2008-08-08ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core中修改配置文件后自動(dòng)加載新配置的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Grid或者DataTable中數(shù)據(jù)導(dǎo)出為Excel原來(lái)這么簡(jiǎn)單
以前一直認(rèn)為,將Grid 或者DataTable中的數(shù)據(jù)導(dǎo)出到Excel功能實(shí)現(xiàn)會(huì)非常復(fù)雜,可能會(huì)想用什么類庫(kù)什么的或者實(shí)在太難就用csv算了,沒(méi)想到真的很簡(jiǎn)單,需要了解的朋友可以參考下2012-12-12