Asp.Net中NHiernate的Session的管理
NHibernate中的Session,在我的理解似乎就相當(dāng)于數(shù)據(jù)庫中連接。因?yàn)樗灿蠴pen/Close的方法,我沒有研究NHibernate的源碼,不知道這種理解是否有誤?我在網(wǎng)上搜了很多的關(guān)于Session的管理,大多都是在我需要數(shù)據(jù)庫操作的時(shí)候,就OpenSession(),操作完后就CloseSession().這有點(diǎn)擬似如我們剛開始學(xué)習(xí)ADO.NET的時(shí)候,要Connection對象Open(),數(shù)據(jù)處理完后就Close().但是這里就帶來了一個(gè)弊端,因?yàn)镃onnection的頻繁的開關(guān)是非常消耗系統(tǒng)資源的。我記得以前在制作一個(gè)數(shù)據(jù)的錄入界面的時(shí),因?yàn)檫@個(gè)錄入的界面數(shù)據(jù)元素比較多,而且很多DropDownList需要在數(shù)據(jù)庫中讀取數(shù)據(jù)并綁定。
這樣在該頁面的Page_Load中需要調(diào)用相應(yīng)對象的方法一一從數(shù)據(jù)庫中檢索數(shù)據(jù)綁定DropDownList.因?yàn)槲覀冞@些對象的方法都是使用獨(dú)立的Connection,都有自己的Connection的Open和Close。所以,導(dǎo)致這個(gè)頁面一打開就需要等待好長的時(shí)間,比較慢。后來我們將這些需要綁定DropDownList的數(shù)據(jù)通過一個(gè)數(shù)據(jù)處理成一個(gè)DataSet,并將DataSet中的DataTable與DropDownList綁定。這樣只需要一次的Connection的Open/Close.頁面快了好多。
所以,我覺得上述的Session的管理辦法不是很妥當(dāng)。
后來,我看了Cuyahoga開源項(xiàng)目中他的Session管理,他使用的“session-per-request”這種模式。從字面上理解就是他為每個(gè)Request創(chuàng)建一個(gè)Session,直到這個(gè)請求銷毀,那么這個(gè)Session也就Close了。而Cuyahoga他的做法和session-per-request有點(diǎn)不同地方就是,他為每個(gè)Request都創(chuàng)建了一個(gè)CoreRepository對象,CoreRepository是系統(tǒng)所需要的數(shù)據(jù)處理服務(wù)的類。他的做法是先創(chuàng)建了HttpModule(NHSessionModule)用來創(chuàng)建CoreRepository對象和銷毀CoreRepository對象,如下:
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();
}
}
這樣在每次請求的時(shí)候,會自動(dòng)創(chuàng)建CoreRepository對象,當(dāng)請求完畢后,就CloseSession(),在程序中通過HttpContext.Current.Items["CoreRepository"]就能獲取CoreRepository對象了。
這樣也就變相的管理了NHibernate中的Session,也就達(dá)到了“session-per-request”的這種模式。
詳細(xì)的講解: 通過實(shí)現(xiàn)IHttpModule初始化Nhibernate的Session
這種方式比上面的那個(gè)每次操作都需要?jiǎng)?chuàng)建Session,性能和速度應(yīng)該提高了不少,接著我就想,每個(gè)請求都創(chuàng)建Session,是不是我們可以象創(chuàng)建Connection Pool一樣,也創(chuàng)建一個(gè)Session Pool,這樣就每次請求的時(shí)候不是直接創(chuàng)建Session,而是在我們的Session Pool中拿已經(jīng)創(chuàng)建好的Session,這樣效率不是更好?!
- 深入淺析TomCat Session管理分析
- Java中tomcat memecached session 共享同步問題的解決辦法
- Tomcat集群和Session復(fù)制應(yīng)用介紹
- JavaWeb Session 會話管理實(shí)例詳解
- Hibernate管理Session和批量操作分析
- PHP 使用MySQL管理Session的回調(diào)函數(shù)詳解
- ASP.NET網(wǎng)站管理系統(tǒng)退出 清除瀏覽器緩存,Session的代碼
- asp.net頁面狀態(tài)管理cookie和服務(wù)器狀態(tài)管理Session
- PHP服務(wù)端SESSION管理工具提供下載
- Tomcat中session的管理機(jī)制
相關(guān)文章
基于ASP.NET+easyUI框架實(shí)現(xiàn)圖片上傳功能(表單)
這篇文章主要介紹了基于ASP.NET+easyUI框架實(shí)現(xiàn)圖片上傳功能的相關(guān)資料,需要的朋友可以參考下2016-06-06ASP.NET組件System.Web.Optimization原理及緩存問題詳解
這篇文章主要介紹了ASP.NET組件System.Web.Optimization的運(yùn)行原理,及基本的緩存問題,感興趣的小伙伴們可以參考一下2016-05-05WCF中使用nettcp協(xié)議進(jìn)行通訊的方法
這篇文章主要給大家介紹了關(guān)于WCF中使用nettcp協(xié)議進(jìn)行通訊的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用WCF具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07利用委托把用戶控件的值顯示于網(wǎng)頁案例應(yīng)用
用戶控件(UserControl)是集成一個(gè)功能,需要處理好的數(shù)據(jù),然后存數(shù)據(jù)庫中并顯示于網(wǎng)頁上,讓用戶能檢測到處理的數(shù)據(jù)情況,接下來將介紹利用委托把用戶控件的值顯示于網(wǎng)頁上,感興趣的朋友可以了解下2013-02-02ASP.NET生成兩個(gè)日期范圍內(nèi)隨機(jī)時(shí)間的實(shí)現(xiàn)方法
這篇文章主要介紹了ASP.NET生成兩個(gè)日期范圍內(nèi)隨機(jī)時(shí)間的實(shí)現(xiàn)方法,通過自定義函數(shù)記錄開始時(shí)間與結(jié)束時(shí)間確定時(shí)間范圍進(jìn)而生成該時(shí)間段的隨機(jī)時(shí)間,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12解決DropDownList總是選中第一項(xiàng)的方法
這篇文章主要介紹了解決DropDownList總是選中第一項(xiàng)的方法,DropDownList下拉框服務(wù)器控件是最常用的控件之一,雖然使用方便,但也會出現(xiàn)奇怪的錯(cuò)誤,感興趣的小伙伴們可以參考一下2015-10-10asp.net 更改gridview pageSize的方法
asp.net 更改gridview pageSize的方法,需要的朋友可以參考下。2011-07-07