實戰(zhàn) .Net 數(shù)據(jù)訪問層 - 18
發(fā)表時間:2023-07-14 來源:明輝站整理相關軟件相關文章人氣:
[摘要]談了些實現(xiàn)問題,來說說幾個題外話:(1) 性能問題:Cache Management能顯著提高數(shù)據(jù)訪問效率,但對內(nèi)存的要求比較高,尤其是在Web Application或Remoting Se...
談了些實現(xiàn)問題,來說說幾個題外話:
(1) 性能問題:Cache Management能顯著提高數(shù)據(jù)訪問效率,但對內(nèi)存的要求比較高,尤其是在Web Application或Remoting Server這種應用環(huán)境下!
所以,這就要求我們應該將“錢”用在“刀刃”上(對內(nèi)存毫不在乎者除外J),不能亂花錢!
一般,對于系統(tǒng)數(shù)據(jù)(如:應用 / 模塊,組 / 用戶 / 權限等)或Lookup Data(如:婚姻狀況列舉 / 政治面貌列舉等),可以考慮放入Cache;另外,如果客戶(請注意:不是開發(fā)人員。┱J為變動可能性較小或頻率不高的Business Data也可以考慮放入Cache;
(2) 手工刷新:Cache是把雙刃劍,帶來便利的同時也增添煩惱。“手工刷新數(shù)據(jù)”可能就是其中最麻煩的事情!
在系統(tǒng)調(diào)試階段,我們還可以通過關閉Cache功能(在配
置信息中注釋掉相關內(nèi)容)來避免這個問題,可一旦上線,
就只能通過其它方式進行解決了!
在這里,作者先試著給出3種解決方案:
i. 對于Web Application,可以利用.NET Framework提供的Dependency機制將Cache綁定至文件系統(tǒng),一旦數(shù)據(jù)變化,只需更新相關文件或目錄信息即可達到Cache Refresh目的(不符合Ease of Use標準L)!但對于Windows Application,Dependency就需要自己實現(xiàn)了L
ii. 可以使用Observer Pattern將所有的Data Access Logic更新操作進行登記,一旦調(diào)用更新方法,立刻執(zhí)行相關delegate以更新Cache Data!
這或許是一個對客戶最為友好的解決方案(有個限制
條件:客戶不能直接修改Database數(shù)據(jù)J),但對開
發(fā)人員卻是一個無盡的“折磨”(整天提心吊膽,總
擔心忘了登記L)!
iii. 自己實現(xiàn)一個UI,對Cache Data進行Refresh Management!這是個介于上面兩種方法間的折衷方案,也是作者比較傾向的一種思路(當然了,如果哪位朋友有興趣將上面3種統(tǒng)統(tǒng)實現(xiàn)并有機整合之,那就功德無量了J)。
最后,奉上作者機器上的Cache部分配置信息供各位參考:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<dafConfiguration>
<dal>
<class name="CustomerDal_ORM">
<method name="GetAllCustomers"
DistributionType="REMOTING"
cacheitem="allcustomers" />
</class>
</dal>
<cache>
<group name="business">
<item name="allcustomers">
<webapp absoluteExpiration="12.0,hour"
priority="High" />
<winapp accessCount="2" />
</item>
</group>
</cache>
</dafConfiguration>
</configuration>
下一段:http://www.csdn.net/develop/Read_Article.asp?id=27562