開啟SQLSERVER數(shù)據(jù)庫緩存依賴優(yōu)化網(wǎng)站性能
更新時(shí)間:2010年04月28日 23:01:02 作者:
開啟SQLSERVER數(shù)據(jù)庫緩存依賴優(yōu)化網(wǎng)站性能
很多時(shí)候,我們服務(wù)器的性能瓶頸會(huì)是在查詢數(shù)據(jù)庫的時(shí)候,所以對(duì)數(shù)據(jù)庫的緩存非常重要,那么有沒有一種方法,可以實(shí)現(xiàn)SQL SERVER數(shù)據(jù)庫的緩存,當(dāng)數(shù)據(jù)表沒有更新時(shí),就從緩存中讀取,當(dāng)有更新的時(shí)候,才從數(shù)據(jù)表中讀取呢,答案是肯定的,這樣的話我們對(duì)一些常用的基礎(chǔ)數(shù)據(jù)表就可以緩存起來,比如做新聞系統(tǒng)的新聞?lì)悇e等,每次就不需要從數(shù)據(jù)庫中讀取了,加快網(wǎng)站的訪問速度。
那么如何開啟SQLSERVER數(shù)據(jù)庫緩存依賴,方法如下:
第一步:修改Web.Config的<system.web>節(jié)的配置,代碼如下,讓網(wǎng)站項(xiàng)目啟用SqlCacheDependency。注意下面代碼中的connectionStringName,就是指定的<connectionStrings>節(jié)中的數(shù)據(jù)庫連接字符串變量名稱。name則是為該SqlCacheDependency起的名字,這個(gè)名字將在第三步中用到。SqlCacheDependency類會(huì)自動(dòng)完成對(duì)此配置節(jié)信息的讀取以建立和數(shù)據(jù)庫之間的聯(lián)系。
<system.web>
<httpHandlers>
<add verb="*" path="*.aspx"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
<add verb="*" path="*.shtml"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
<add verb="*" path="*.bobo"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
</httpHandlers>
<!-->以下設(shè)置數(shù)據(jù)庫緩存依賴方式-->
<caching>
<sqlCacheDependency enabled="true" pollTime="6000">
<databases>
<add name="YD_JWC_JAKE" connectionStringName="cachestr"/>
</databases>
</sqlCacheDependency>
</caching>
<!--
設(shè)置 compilation debug="true" 將調(diào)試符號(hào)插入
已編譯的頁面中。但由于這會(huì)
影響性能,因此只在開發(fā)過程中將此值
設(shè)置為 true。
-->
<compilation debug="true">
<assemblies>
<add assembly="System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A"/>
</assemblies>
</compilation>
<!--
通過 <authentication> 節(jié)可以配置 ASP.NET 使用的
安全身份驗(yàn)證模式,
以標(biāo)識(shí)傳入的用戶。
-->
<authentication mode="Forms">
<forms loginUrl="login.aspx" name=".AJSUPCXAIUTH"></forms>
</authentication>
<authorization>
<allow users="*"/>
</authorization>
<!--
如果在執(zhí)行請(qǐng)求的過程中出現(xiàn)未處理的錯(cuò)誤,
則通過 <customErrors> 節(jié)可以配置相應(yīng)的處理步驟。具體說來,
開發(fā)人員通過該節(jié)可以配置
要顯示的 html 錯(cuò)誤頁
以代替錯(cuò)誤堆棧跟蹤。-->
<customErrors mode="RemoteOnly" defaultRedirect="/ER3.shtml">
<error statusCode="403" redirect="/ER1.shtml" />
<error statusCode="404" redirect="/ER404.shtml" />
</customErrors>
</system.web>
第二步:在CMD中執(zhí)行下述命令,以開啟SQL SERVER數(shù)據(jù)庫對(duì)SqlCacheDependency的支持,利用aspnet_regsql.exe工具,該工具位于windows\microsoft.net\framework\[版本]文件夾中
代碼如下:
aspnet_regsql -C "data source=127.0.0.1;initial catalog=YD_JWC_JAKE;user id=sa;password=" -ed -et -t "T_NewsClass"
參數(shù)-C后面跟著的是數(shù)據(jù)庫連接字符串,注意字母C是大寫。參數(shù)-t后面跟著的就是你要開啟數(shù)據(jù)庫緩存的數(shù)據(jù)表,此處我為新聞?lì)悇e的表開啟了緩存依賴。(如果有多個(gè)表,則重復(fù)執(zhí)行此命令,注意修改你的數(shù)據(jù)表名)
第三步:在獲取數(shù)據(jù)的業(yè)務(wù)層代碼中,如果是第一次讀取,則從數(shù)據(jù)庫中讀取后,存入緩存里。以后獲取數(shù)據(jù)時(shí),數(shù)據(jù)庫會(huì)自動(dòng)判斷表是否有更新數(shù)據(jù),如果有,則讀數(shù)據(jù)庫同時(shí)更新緩存,如果沒有更新,則從數(shù)據(jù)庫中讀取。代碼如下:
private void getInfoClass( int t)
{
string CacheKey = "cacheclass" + t.ToString();
object objModle = Jake.DataCache.GetCache(CacheKey);//從緩存中獲取
DataTable dt=null;
if (objModle == null)//如果緩存中沒有則讀取數(shù)據(jù)庫
{
Jake.BLL.NewsManage.NewsClass nc = new Jake.BLL.NewsManage.NewsClass();
dt = nc.GetList("").Tables[0];
objModle = dt;
if (objModle != null)
{
System.Web.Caching.SqlCacheDependency dep = new System.Web.Caching.SqlCacheDependency("YD_JWC_JAKE", "T_NewsClass");
Jake.DataCache.SetCache(CacheKey, objModle, dep);
}
}
else
{
dt = (DataTable)objModle; //緩存中有就直接讀取緩存,不需要訪問數(shù)據(jù)庫
}
DataRow[] drs = dt.Select("","classid");
StringBuilder sb =new StringBuilder();
sb.Append("<ul>");
foreach (DataRow r in drs)
{
string cid=r["ClassId"].ToString();
Security js = new Security();
string decrystr = Jake.Common.ConfigHelper.GetConfigString("DecryStr");//獲得加密密鑰
cid = js.EncryptQueryString(cid, decrystr);
string cdesc=r["ClassDesc"].ToString();
if (t == 1)
{
sb.Append("<li><a href="/Info" + cid + ".shtml" href="Info" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
else if (t == 2)
{
sb.Append("<li><a href="/File" + cid +".shtml" href="File" + cid +".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
else
sb.Append("<li><a href="/FAQ" + cid + ".shtml" href="FAQ" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
sb.Append("</ul>");
Response.Write(sb);
}
以上代碼中Jake.DataCache.GetCache()方法是自己定義的一個(gè)獲取和設(shè)置緩存的通用方法,單獨(dú)編譯成了DLL:
代碼如下:
using System;
using System.Collections.Generic;
using System.Web;
using System.Text;
namespace Jake
{
public class DataCache
{
/// <summary>
/// 獲取當(dāng)前應(yīng)用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <returns></returns>
public static object GetCache(string CacheKey)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
return objCache[CacheKey];
}
/// <summary>
/// 設(shè)置當(dāng)前應(yīng)用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <param name="objObject"></param>
public static void SetCache(string CacheKey, object objObject)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(CacheKey, objObject);
}
/// <summary>
/// 設(shè)置已緩存依賴的方式緩存數(shù)據(jù)
/// </summary>
/// <param name="CacheKey">鍵值</param>
/// <param name="objObject">緩存對(duì)象</param>
/// <param name="dep">緩存依賴項(xiàng)</param>
public static void SetCache(string CacheKey, object objObject, System.Web.Caching.CacheDependency dep)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(
CacheKey,
objObject,
dep,
System.Web.Caching.Cache.NoAbsoluteExpiration,//從不過期
System.Web.Caching.Cache.NoSlidingExpiration,//禁用可調(diào)過期
System.Web.Caching.CacheItemPriority.Default,
null
);
}
}
}
至此,對(duì)于數(shù)據(jù)表的緩存依賴就已經(jīng)開啟,這樣可以大大加快網(wǎng)站訪問的速度。
(轉(zhuǎn)載請(qǐng)注明本文出處:http://blog.csdn.net/j_jake)
那么如何開啟SQLSERVER數(shù)據(jù)庫緩存依賴,方法如下:
第一步:修改Web.Config的<system.web>節(jié)的配置,代碼如下,讓網(wǎng)站項(xiàng)目啟用SqlCacheDependency。注意下面代碼中的connectionStringName,就是指定的<connectionStrings>節(jié)中的數(shù)據(jù)庫連接字符串變量名稱。name則是為該SqlCacheDependency起的名字,這個(gè)名字將在第三步中用到。SqlCacheDependency類會(huì)自動(dòng)完成對(duì)此配置節(jié)信息的讀取以建立和數(shù)據(jù)庫之間的聯(lián)系。
復(fù)制代碼 代碼如下:
<system.web>
<httpHandlers>
<add verb="*" path="*.aspx"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
<add verb="*" path="*.shtml"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
<add verb="*" path="*.bobo"
type="URLRewriter.RewriterFactoryHandler, URLRewriter" />
</httpHandlers>
<!-->以下設(shè)置數(shù)據(jù)庫緩存依賴方式-->
<caching>
<sqlCacheDependency enabled="true" pollTime="6000">
<databases>
<add name="YD_JWC_JAKE" connectionStringName="cachestr"/>
</databases>
</sqlCacheDependency>
</caching>
<!--
設(shè)置 compilation debug="true" 將調(diào)試符號(hào)插入
已編譯的頁面中。但由于這會(huì)
影響性能,因此只在開發(fā)過程中將此值
設(shè)置為 true。
-->
<compilation debug="true">
<assemblies>
<add assembly="System.Design, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A"/>
</assemblies>
</compilation>
<!--
通過 <authentication> 節(jié)可以配置 ASP.NET 使用的
安全身份驗(yàn)證模式,
以標(biāo)識(shí)傳入的用戶。
-->
<authentication mode="Forms">
<forms loginUrl="login.aspx" name=".AJSUPCXAIUTH"></forms>
</authentication>
<authorization>
<allow users="*"/>
</authorization>
<!--
如果在執(zhí)行請(qǐng)求的過程中出現(xiàn)未處理的錯(cuò)誤,
則通過 <customErrors> 節(jié)可以配置相應(yīng)的處理步驟。具體說來,
開發(fā)人員通過該節(jié)可以配置
要顯示的 html 錯(cuò)誤頁
以代替錯(cuò)誤堆棧跟蹤。-->
<customErrors mode="RemoteOnly" defaultRedirect="/ER3.shtml">
<error statusCode="403" redirect="/ER1.shtml" />
<error statusCode="404" redirect="/ER404.shtml" />
</customErrors>
</system.web>
第二步:在CMD中執(zhí)行下述命令,以開啟SQL SERVER數(shù)據(jù)庫對(duì)SqlCacheDependency的支持,利用aspnet_regsql.exe工具,該工具位于windows\microsoft.net\framework\[版本]文件夾中
代碼如下:
復(fù)制代碼 代碼如下:
aspnet_regsql -C "data source=127.0.0.1;initial catalog=YD_JWC_JAKE;user id=sa;password=" -ed -et -t "T_NewsClass"
參數(shù)-C后面跟著的是數(shù)據(jù)庫連接字符串,注意字母C是大寫。參數(shù)-t后面跟著的就是你要開啟數(shù)據(jù)庫緩存的數(shù)據(jù)表,此處我為新聞?lì)悇e的表開啟了緩存依賴。(如果有多個(gè)表,則重復(fù)執(zhí)行此命令,注意修改你的數(shù)據(jù)表名)
第三步:在獲取數(shù)據(jù)的業(yè)務(wù)層代碼中,如果是第一次讀取,則從數(shù)據(jù)庫中讀取后,存入緩存里。以后獲取數(shù)據(jù)時(shí),數(shù)據(jù)庫會(huì)自動(dòng)判斷表是否有更新數(shù)據(jù),如果有,則讀數(shù)據(jù)庫同時(shí)更新緩存,如果沒有更新,則從數(shù)據(jù)庫中讀取。代碼如下:
復(fù)制代碼 代碼如下:
private void getInfoClass( int t)
{
string CacheKey = "cacheclass" + t.ToString();
object objModle = Jake.DataCache.GetCache(CacheKey);//從緩存中獲取
DataTable dt=null;
if (objModle == null)//如果緩存中沒有則讀取數(shù)據(jù)庫
{
Jake.BLL.NewsManage.NewsClass nc = new Jake.BLL.NewsManage.NewsClass();
dt = nc.GetList("").Tables[0];
objModle = dt;
if (objModle != null)
{
System.Web.Caching.SqlCacheDependency dep = new System.Web.Caching.SqlCacheDependency("YD_JWC_JAKE", "T_NewsClass");
Jake.DataCache.SetCache(CacheKey, objModle, dep);
}
}
else
{
dt = (DataTable)objModle; //緩存中有就直接讀取緩存,不需要訪問數(shù)據(jù)庫
}
DataRow[] drs = dt.Select("","classid");
StringBuilder sb =new StringBuilder();
sb.Append("<ul>");
foreach (DataRow r in drs)
{
string cid=r["ClassId"].ToString();
Security js = new Security();
string decrystr = Jake.Common.ConfigHelper.GetConfigString("DecryStr");//獲得加密密鑰
cid = js.EncryptQueryString(cid, decrystr);
string cdesc=r["ClassDesc"].ToString();
if (t == 1)
{
sb.Append("<li><a href="/Info" + cid + ".shtml" href="Info" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
else if (t == 2)
{
sb.Append("<li><a href="/File" + cid +".shtml" href="File" + cid +".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
else
sb.Append("<li><a href="/FAQ" + cid + ".shtml" href="FAQ" + cid + ".shtml"><span class='fontbold'>" + cdesc + "</span></a></li>");
}
sb.Append("</ul>");
Response.Write(sb);
}
以上代碼中Jake.DataCache.GetCache()方法是自己定義的一個(gè)獲取和設(shè)置緩存的通用方法,單獨(dú)編譯成了DLL:
代碼如下:
復(fù)制代碼 代碼如下:
using System;
using System.Collections.Generic;
using System.Web;
using System.Text;
namespace Jake
{
public class DataCache
{
/// <summary>
/// 獲取當(dāng)前應(yīng)用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <returns></returns>
public static object GetCache(string CacheKey)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
return objCache[CacheKey];
}
/// <summary>
/// 設(shè)置當(dāng)前應(yīng)用程序指定CacheKey的Cache值
/// </summary>
/// <param name="CacheKey"></param>
/// <param name="objObject"></param>
public static void SetCache(string CacheKey, object objObject)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(CacheKey, objObject);
}
/// <summary>
/// 設(shè)置已緩存依賴的方式緩存數(shù)據(jù)
/// </summary>
/// <param name="CacheKey">鍵值</param>
/// <param name="objObject">緩存對(duì)象</param>
/// <param name="dep">緩存依賴項(xiàng)</param>
public static void SetCache(string CacheKey, object objObject, System.Web.Caching.CacheDependency dep)
{
System.Web.Caching.Cache objCache = HttpRuntime.Cache;
objCache.Insert(
CacheKey,
objObject,
dep,
System.Web.Caching.Cache.NoAbsoluteExpiration,//從不過期
System.Web.Caching.Cache.NoSlidingExpiration,//禁用可調(diào)過期
System.Web.Caching.CacheItemPriority.Default,
null
);
}
}
}
至此,對(duì)于數(shù)據(jù)表的緩存依賴就已經(jīng)開啟,這樣可以大大加快網(wǎng)站訪問的速度。
(轉(zhuǎn)載請(qǐng)注明本文出處:http://blog.csdn.net/j_jake)
您可能感興趣的文章:
- sqlserver數(shù)據(jù)庫規(guī)模膨脹太大怎么優(yōu)化
- SQL Server 聚焦存儲(chǔ)過程性能優(yōu)化、數(shù)據(jù)壓縮和頁壓縮提高IO性能方法(一)
- 日常收集整理SqlServer數(shù)據(jù)庫優(yōu)化經(jīng)驗(yàn)和注意事項(xiàng)
- SQL server 2008 數(shù)據(jù)庫優(yōu)化常用腳本
- sqlserver數(shù)據(jù)庫優(yōu)化解析(圖文剖析)
- sqlserver關(guān)于分頁存儲(chǔ)過程的優(yōu)化【讓數(shù)據(jù)庫按我們的意思執(zhí)行查詢計(jì)劃】
- SQL Server數(shù)據(jù)庫的高性能優(yōu)化經(jīng)驗(yàn)總結(jié)
- SQL Server 數(shù)據(jù)庫優(yōu)化
- SQL Server數(shù)據(jù)庫性能優(yōu)化技術(shù)
- SQL Server 數(shù)據(jù)太多優(yōu)化的方法
相關(guān)文章
asp.net中倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)頁面的實(shí)現(xiàn)方法(使用javascript)
本篇文章介紹了,asp.net中倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)頁面的實(shí)現(xiàn)方法(使用javascript)。需要的朋友參考下2013-05-05Web API身份認(rèn)證解決方案之Basic基礎(chǔ)認(rèn)證
本文詳細(xì)講解了Web API身份認(rèn)證解決方案之Basic基礎(chǔ)認(rèn)證,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03看到本質(zhì)而不是現(xiàn)象--解決ASP.NET CS0016的問題
看到本質(zhì)而不是現(xiàn)象--解決ASP.NET CS0016的問題...2007-01-01ASP.Net使用System.Security.Principal模擬用戶
這篇文章介紹了ASP.Net使用System.Security.Principal模擬用戶的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法
本篇文章小編將為大家介紹,關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法,有需要的朋友可以參考一下2013-04-04asp.net 在DNN模塊開發(fā)中遇到的resx怪問題
最近我遇到2個(gè)小問題,在此記錄一下。這是我發(fā)的帖子2008-11-11