Asp.Net中NHiernate的Session的管理
NHibernate中的Session,在我的理解似乎就相當(dāng)于數(shù)據(jù)庫(kù)中連接。因?yàn)樗灿蠴pen/Close的方法,我沒(méi)有研究NHibernate的源碼,不知道這種理解是否有誤?我在網(wǎng)上搜了很多的關(guān)于Session的管理,大多都是在我需要數(shù)據(jù)庫(kù)操作的時(shí)候,就OpenSession(),操作完后就CloseSession().這有點(diǎn)擬似如我們剛開(kāi)始學(xué)習(xí)ADO.NET的時(shí)候,要Connection對(duì)象Open(),數(shù)據(jù)處理完后就Close().但是這里就帶來(lái)了一個(gè)弊端,因?yàn)镃onnection的頻繁的開(kāi)關(guān)是非常消耗系統(tǒng)資源的。我記得以前在制作一個(gè)數(shù)據(jù)的錄入界面的時(shí),因?yàn)檫@個(gè)錄入的界面數(shù)據(jù)元素比較多,而且很多DropDownList需要在數(shù)據(jù)庫(kù)中讀取數(shù)據(jù)并綁定。
這樣在該頁(yè)面的Page_Load中需要調(diào)用相應(yīng)對(duì)象的方法一一從數(shù)據(jù)庫(kù)中檢索數(shù)據(jù)綁定DropDownList.因?yàn)槲覀冞@些對(duì)象的方法都是使用獨(dú)立的Connection,都有自己的Connection的Open和Close。所以,導(dǎo)致這個(gè)頁(yè)面一打開(kāi)就需要等待好長(zhǎng)的時(shí)間,比較慢。后來(lái)我們將這些需要綁定DropDownList的數(shù)據(jù)通過(guò)一個(gè)數(shù)據(jù)處理成一個(gè)DataSet,并將DataSet中的DataTable與DropDownList綁定。這樣只需要一次的Connection的Open/Close.頁(yè)面快了好多。
所以,我覺(jué)得上述的Session的管理辦法不是很妥當(dāng)。
后來(lái),我看了Cuyahoga開(kāi)源項(xiàng)目中他的Session管理,他使用的“session-per-request”這種模式。從字面上理解就是他為每個(gè)Request創(chuàng)建一個(gè)Session,直到這個(gè)請(qǐng)求銷(xiāo)毀,那么這個(gè)Session也就Close了。而Cuyahoga他的做法和session-per-request有點(diǎn)不同地方就是,他為每個(gè)Request都創(chuàng)建了一個(gè)CoreRepository對(duì)象,CoreRepository是系統(tǒng)所需要的數(shù)據(jù)處理服務(wù)的類(lèi)。他的做法是先創(chuàng)建了HttpModule(NHSessionModule)用來(lái)創(chuàng)建CoreRepository對(duì)象和銷(xiāo)毀CoreRepository對(duì)象,如下:
private void Context_BeginRequest(object sender, EventArgs e)
{
// Create the repository for Core objects and add it to the current HttpContext.
CoreRepository cr = new CoreRepository(true);
HttpContext.Current.Items.Add("CoreRepository", cr);
}
private void Context_EndRequest(object sender, EventArgs e)
{
// Close the NHibernate session.
if (HttpContext.Current.Items["CoreRepository"] != null)
{
CoreRepository cr = (CoreRepository)HttpContext.Current.Items["CoreRepository"];
cr.CloseSession();
}
}
這樣在每次請(qǐng)求的時(shí)候,會(huì)自動(dòng)創(chuàng)建CoreRepository對(duì)象,當(dāng)請(qǐng)求完畢后,就CloseSession(),在程序中通過(guò)HttpContext.Current.Items["CoreRepository"]就能獲取CoreRepository對(duì)象了。
這樣也就變相的管理了NHibernate中的Session,也就達(dá)到了“session-per-request”的這種模式。
詳細(xì)的講解: 通過(guò)實(shí)現(xiàn)IHttpModule初始化Nhibernate的Session
這種方式比上面的那個(gè)每次操作都需要?jiǎng)?chuàng)建Session,性能和速度應(yīng)該提高了不少,接著我就想,每個(gè)請(qǐng)求都創(chuàng)建Session,是不是我們可以象創(chuàng)建Connection Pool一樣,也創(chuàng)建一個(gè)Session Pool,這樣就每次請(qǐng)求的時(shí)候不是直接創(chuàng)建Session,而是在我們的Session Pool中拿已經(jīng)創(chuàng)建好的Session,這樣效率不是更好?!
- 深入淺析TomCat Session管理分析
- Java中tomcat memecached session 共享同步問(wèn)題的解決辦法
- Tomcat集群和Session復(fù)制應(yīng)用介紹
- JavaWeb Session 會(huì)話(huà)管理實(shí)例詳解
- Hibernate管理Session和批量操作分析
- PHP 使用MySQL管理Session的回調(diào)函數(shù)詳解
- ASP.NET網(wǎng)站管理系統(tǒng)退出 清除瀏覽器緩存,Session的代碼
- asp.net頁(yè)面狀態(tài)管理cookie和服務(wù)器狀態(tài)管理Session
- PHP服務(wù)端SESSION管理工具提供下載
- Tomcat中session的管理機(jī)制
相關(guān)文章
.NET微信公眾號(hào)開(kāi)發(fā)之查詢(xún)自定義菜單
本文給大家講述的是.NET微信公眾號(hào)開(kāi)發(fā)系列文章的第三篇,主要給大家講解下查詢(xún)自定義菜單的相關(guān)內(nèi)容,有需要的小伙伴可以參考下。2015-07-07
ASP.NET配合jQuery解決跨域調(diào)用的問(wèn)題
這篇文章主要介紹了ASP.NET配合jQuery解決跨域調(diào)用的問(wèn)題,簡(jiǎn)單實(shí)用,需要的朋友可以參考下。2016-06-06
sql server中批量插入與更新兩種解決方案分享(asp.net)
xml和表值函數(shù)的相對(duì)復(fù)雜些這里簡(jiǎn)單貼一下bcp和SqlDataAdapter進(jìn)行批量跟新插入方法,未經(jīng)整理還望見(jiàn)諒2012-05-05
MVC使用Controller代替Filter完成登錄驗(yàn)證(Session校驗(yàn))學(xué)習(xí)筆記5
這篇文章主要介紹了MVC使用Controller代替Filter完成登錄驗(yàn)證即Session校驗(yàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
asp.net 刪除MFC單文檔默認(rèn)菜單欄的兩種方法
新建一個(gè)MFC單文檔程序,默認(rèn)都有四個(gè)菜單欄:文件、編輯、視圖和幫助。怎么把這四個(gè)菜單欄刪除掉呢?2010-03-03
WPF實(shí)現(xiàn)帶全選復(fù)選框的列表控件
這篇文章主要為大家詳細(xì)介紹了WPF實(shí)現(xiàn)帶全選復(fù)選框的列表控件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
asp.net MVC實(shí)現(xiàn)無(wú)組件上傳圖片實(shí)例介紹
無(wú)組件實(shí)現(xiàn)上傳圖片使用input的file作為上傳選擇文件,具體實(shí)現(xiàn)如下:前后臺(tái)代碼很詳細(xì),感興趣的朋友們可不要錯(cuò)過(guò)了哈2013-05-05
詳解Asp.Net Core 2.1+的視圖緩存(響應(yīng)緩存)
本篇文章給大家通過(guò)實(shí)例講述了Asp.Net Core 2.1+的視圖緩存(響應(yīng)緩存)的相關(guān)知識(shí)點(diǎn),對(duì)此有興趣的讀者們可以學(xué)習(xí)下。2018-03-03

