網站開發

          asp.net
          隨筆 - 30, 文章 - 0, 評論 - 9, 引用 - 0
          數據加載中……

          ASP.NET應用中十大常見的潛在問題

          Jeff Prosise在《MSDN雜志》2006年7月期上的文章歷數ASP.NET應用中常見的,容易出錯,影響性能和擴縮性的潛在問題

          Keep Sites Running Smoothly By Avoiding These 10 Common ASP.NET Pitfalls
          http://msdn.microsoft.com/msdnmag/issues/06/07/WebAppFollies/

          1。設置輸出緩存的用戶控件,如果用LoadControl動態裝載,LoadControl返回對象屬于PartialCachingControl類,其中的CachedControl也許并不存在,無法轉換成原用戶控件對象類

          2。在 IIS 6.0 中,在設置kernel模式輸出緩存的情形下,OutputCacheModule模塊有時會保留緩存輸出的Set-Cookie header,導致會話串門(cross-session),即一個用戶能看到其他用戶的會話數據

          具體參考KB文章
          An ASP.NET page is stored in the HTTP.sys kernel cache in IIS 6.0 when the ASP.NET page generates an HTTP header that contains a Set-Cookie response
          http://support.microsoft.com/kb/917072

          或者禁止kernel模式輸出緩存
          <httpRuntime enableKernelOutputCache="false" />

          具體參考
          http://support.microsoft.com/kb/820129

          3。 Forms 認證Ticket的存活時間。在ASP.NET 1.*中,在沒有用編碼設置的情形下,如果是持久保存,存活時間是50年,如果是非持久保存,存活時間是30分鐘。這個問題在ASP.NET 2.0中已經解決,默認存活時間會用web.config里的設置。在ASP.NET 1.*中,只能用編碼來解決,具體編碼參考原文中的例子。

          4。 View State,如果濫用的話,是無聲的性能殺手,特別是DataGrids和GridViews等,應該設置EnableViewState=false,或者考慮通過更改LoadPageStateFromPersistenceMedium/SavePageStateToPersistenceMedium把View State放在服務器端。

          5。如果使用SQL Server做會話狀態服務器的話,默認情形下,每個請求會訪問狀態服務器2次,造成性能下降。解決方案是,在不用會話狀態的頁面里,設置

          <%@ Page EnableSessionState="false" ... %>

          在只讀會話狀態的頁面里,設置

          <%@ Page EnableSessionState="ReadOnly" ... %>

          6。在ASP.NET 2.0應用中,如果在web.config里設置

          <roleManager enabled="true" />

          默認情形下,角色數據是不緩存的,如果角色管理器需要確認當前用戶的角色的話,會訪問數據庫,導致性能下降,解決方案是設置把角色數據緩存在Cookie里(這個Cookie是加過密的)

          <roleManager enabled="true" cacheRolesInCookie="true" />

          7。Profile 特性持久化問題,在默認情形下,ASP.NET profile管理器使用XML持久機制持久化自定義Profile類,不保存這些類的私有成員,解決方案是把這些類標為[Serializable]或實現ISerializable ,這樣profile管理器會使用binary serializer

          8。過長的數據庫查詢或I/O操作會導致線程池的飽和,導致ASP.NET的性能下降。ASP.NET 2.0提供了異步網頁(asynchronous page)機制來緩解這個問題。具體參考Jeff Prosise在《MSDN雜志》2005年10月期上的文章

          Asynchronous Pages in ASP.NET 2.0
          http://msdn.microsoft.com/msdnmag/issues/05/10/WickedCode/

          9。<identity impersonate="true" /> 導致客戶端用戶的身份模擬,要慎用,避免用身份模擬(Impersonation)替代ACL授權。

          10。別太有信心,多用Profiler剖析你的應用對數據庫的訪問情形。重視數據庫的設計,認識到DataSet和DataAdapter對web應用也許并不合適,數據訪問層要恰當設計,防止粗劣細分(poor factorization),避免在相對簡單的操作上浪費太多的CPU周期,導致性能下降

          posted on 2006-11-07 14:08 風雨兼程 閱讀(181) 評論(0)  編輯  收藏 所屬分類: Asp.net

          主站蜘蛛池模板: 黄骅市| 神农架林区| 临江市| 舒城县| 汾西县| 东乡县| 万州区| 台湾省| 扎赉特旗| 罗山县| 云安县| 云浮市| 神农架林区| 遵义县| 邹平县| 舟山市| 固安县| 洛隆县| 天门市| 平顺县| 青神县| 逊克县| 仲巴县| 翁牛特旗| 咸阳市| 讷河市| 郯城县| 乌海市| 扶沟县| 贺兰县| 凌海市| 开平市| 渭源县| 温宿县| 荃湾区| 岢岚县| 买车| 金山区| 陵川县| 偏关县| 新宾|