注:該問題已解決,詳見終於解決“百年一遇”奇怪問題。
一個是微軟的 IE,一個是微軟的 .NET Framework 4.5,竟然出現如此離奇的問題,不得不讓人想起一句詩句:“本是同根生,相煎何太急”。
下面我們來一睹這個百年一遇的奇怪問題。
問題背景
最近將 job.cnblogs.com 項目中的 Entity Framework 升級到了 5.0,據說 EF 5.0 在 .NET Framework 4.5 之下性能會有大幅提升(相關博文),於是在服務器上安裝了 .NET Framework 4.5。
安裝后發現,.NET Framework 4.5 並沒有在 C:\Windows\Microsoft.NET 中創建新的文件夾,都安裝在了 .NET Framework 4.0 文件夾中,並且更新了 .NET Framework 4.0 中的很多 dll 文件,比如 System.Web.dll, System.Web.Routing.dll...
老規矩,安裝后需要重啟服務器,重啟后測試了所有站點(IIS 7 + ASP.NET MVC 3 + WebForms),未發現任何異常。
問題現象
接着,陸陸續續有園友反映訪問閃存(home.cnblogs.com/ing/)很卡,開始以為是網絡線路問題。后來發現出現問題的用戶用的都是 IE 8,以為是 js 代碼的瀏覽器兼容問題引起的,於是檢查 js 代碼,在這個過程中無意間重現了這個問題, 而且用的是 IE 9。
用戶所說的“很卡”究竟是什么樣一種情況,請看下圖:
“卡”也就是瀏覽器標簽窗口上的小圖標一直處於旋轉狀態(等待服務器響應)。
按 F12 打開 IE 的開發者工具,發現瀏覽器發出請求后,服務器一直沒有響應。說明這個問題與 js 沒有任何關系,是服務器端請求處理問題。
(這時你也許會有疑問,這個問題我們自己怎么沒發現?不就是點一下 IE,幾秒鍾的事情。可是問題沒這么簡單,用 IE 第一次訪問一切正常,問題出在后續的請求,通常是第三次請求。我們主要用的瀏覽器是 Chrome 與 Firefox,所以測試時,用 IE 打開一下,看沒問題就關掉了。)
出現“卡”的問題后,即使重新打開瀏覽器標簽也是同樣的問題,唯一的解決方法是退出整個IE,並重新打開。
問題奇怪之處
問題奇怪之一:服務器是微軟的 ASP.NET 環境,出問題的不是其他瀏覽器,而是微軟自己的 IE 瀏覽器。(想不通)
問題奇怪之二:IE 第一次請求不會出現問題,問題只出現在后續請求中。(難道與瀏覽器的Last-Modified有關)
問題奇怪之三:同一台服務器,有多個站點,只有這一個站點會出現這個問題。同一個站點(home.cnblogs.com),只有主頁與閃存相關頁面會出現這個問題。(可能是某個操作引起的)
問題奇怪之四:WebForms 與 MVC 都會出現這個問題。這個站點是 WebForms 與 ASP.NET MVC 的混合環境,出現問題的頁面是 WebForms 頁面,但這些頁面的 ajax 是請求由 MVC 處理的,也會有同樣的問題。(這個操作可能 WebForms 與 MVC 都會用到)
問題奇怪之五:在 Global.asax 中取消所有 MVC 的路由注冊(routes.MapRoute),問題就消失。(這個問題可能與WebForms 與 ASP.NET MVC 的混合環境有關)
問題原因確認
為了確認這個問題是不是 .NET Framework 4.5 引起的?我們在測試環境中將 .NET Framework 4.5 卸載。這時遇到另一個郁悶的問題,卸載 .NET Framework 4.5 之后,.NET Framework 4.0 也沒了,更讓人郁悶的是 IIS 中所有使用 .NET Framework 4.0 的應用程序池都被改為了 .NET Framework 2.0,這個卸載真“干凈”。安裝 .NET Framework 4.0 之后,問題立即消失;重新安裝 .NET Framework 4.5,問題立即出現。不管具體是哪個操作引起的,.NET Framework 4.5 是罪魁禍首。
問題處理
昨天一天的奮戰沒有找出具體是哪個操作引起的,今天繼續努力!
如果實在找不出,只能先卸載 .NET Framework 4.5,重新安裝 .NET Framework 4.0。
問題相關代碼
ASP.NET MVC 路由注冊代碼:
public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapPageRoute("Default", "", "~/Default.aspx"); routes.MapRoute( "DefaultMvcAjax", "ajax/{controller}/{action}/{id}", new { controller = "", action = "", id = "" } ); routes.MapRoute( "IngMovileMvc", "ing/mobile/{action}/{ingListType}/{pageIndex}", new { controller = "IngMobile", action = "Home", ingListType = CNBlogs.UcHome.Entities.IngListType.all, pageIndex = 1 } ); routes.MapRoute( "DefaultMvc", "{controller}/{action}/{id}", new { controller = "Msg", action = "List", id = "" } ); }
出現問題的訪問路徑:根路徑與 ing/default.aspx,這兩個路徑訪問的都是實際的 .aspx 文件。
問題補充
用 IE9 開發者工具查看請求信息,Request headers, Request body, Response headers, Response body 全為空,只有 Timings 中有內容,見下圖: