一個是微軟的 IE,一個是微軟的 .NET Framework 4.5,竟然出現(xiàn)如此離奇的問題,不得不讓人想起一句詩句:“本是同根生,相煎何太急”。
下面我們來一睹這個百年一遇的奇怪問題。
問題背景
最近將 job.cnblogs.com 項目中的 Entity Framework 升級到了 5.0,據(jù)說 EF 5.0 在 .NET Framework 4.5 之下性能會有大幅提升(相關(guān)博文),于是在服務(wù)器上安裝了 .NET Framework 4.5。
安裝后發(fā)現(xiàn),.NET Framework 4.5 并沒有在 C:\Windows\Microsoft.NET 中創(chuàng)建新的文件夾,都安裝在了 .NET Framework 4.0 文件夾中,并且更新了 .NET Framework 4.0 中的很多 dll 文件,比如 System.Web.dll, System.Web.Routing.dll...
老規(guī)矩,安裝后需要重啟服務(wù)器,重啟后測試了所有站點(IIS 7 + ASP.NET MVC 3 + WebForms),未發(fā)現(xiàn)任何異常。
問題現(xiàn)象
接著,陸陸續(xù)續(xù)有園友反映訪問閃存(home.cnblogs.com/ing/)很卡,開始以為是網(wǎng)絡(luò)線路問題。后來發(fā)現(xiàn)出現(xiàn)問題的用戶用的都是 IE 8,以為是 js 代碼的瀏覽器兼容問題引起的,于是檢查 js 代碼,在這個過程中無意間重現(xiàn)了這個問題, 而且用的是 IE 9。
用戶所說的“很卡”究竟是什么樣一種情況,請看下圖:
“卡”也就是瀏覽器標簽窗口上的小圖標一直處于旋轉(zhuǎn)狀態(tài)(等待服務(wù)器響應(yīng))。
按 F12 打開 IE 的開發(fā)者工具,發(fā)現(xiàn)瀏覽器發(fā)出請求后,服務(wù)器一直沒有響應(yīng)。說明這個問題與 js 沒有任何關(guān)系,是服務(wù)器端請求處理問題。
(這時你也許會有疑問,這個問題我們自己怎么沒發(fā)現(xiàn)?不就是點一下 IE,幾秒鐘的事情?墒菃栴}沒這么簡單,用 IE 第一次訪問一切正常,問題出在后續(xù)的請求,通常是第三次請求。我們主要用的瀏覽器是 Chrome 與 Firefox,所以測試時,用 IE 打開一下,看沒問題就關(guān)掉了。)
出現(xiàn)“卡”的問題后,即使重新打開瀏覽器標簽也是同樣的問題,唯一的解決方法是退出整個IE,并重新打開。
問題奇怪之處
問題奇怪之一:服務(wù)器是微軟的 ASP.NET 環(huán)境,出問題的不是其他瀏覽器,而是微軟自己的 IE 瀏覽器。(想不通)
問題奇怪之二:IE 第一次請求不會出現(xiàn)問題,問題只出現(xiàn)在后續(xù)請求中。(難道與瀏覽器的Last-Modified有關(guān))
問題奇怪之三:同一臺服務(wù)器,有多個站點,只有這一個站點會出現(xiàn)這個問題。同一個站點(home.cnblogs.com),只有主頁與閃存相關(guān)頁面會出現(xiàn)這個問題。(可能是某個操作引起的)
問題奇怪之四:WebForms 與 MVC 都會出現(xiàn)這個問題。這個站點是 WebForms 與 ASP.NET MVC 的混合環(huán)境,出現(xiàn)問題的頁面是 WebForms 頁面,但這些頁面的 ajax 是請求由 MVC 處理的,也會有同樣的問題。(這個操作可能 WebForms 與 MVC 都會用到)
問題奇怪之五:在 Global.asax 中取消所有 MVC 的路由注冊(routes.MapRoute),問題就消失。(這個問題可能與WebForms 與 ASP.NET MVC 的混合環(huán)境有關(guān))
問題原因確認
為了確認這個問題是不是 .NET Framework 4.5 引起的?我們在測試環(huán)境中將 .NET Framework 4.5 卸載。這時遇到另一個郁悶的問題,卸載 .NET Framework 4.5 之后,.NET Framework 4.0 也沒了,更讓人郁悶的是 IIS 中所有使用 .NET Framework 4.0 的應(yīng)用程序池都被改為了 .NET Framework 2.0,這個卸載真“干凈”。安裝 .NET Framework 4.0 之后,問題立即消失;重新安裝 .NET Framework 4.5,問題立即出現(xiàn)。不管具體是哪個操作引起的,.NET Framework 4.5 是罪魁禍首。
問題處理
昨天一天的奮戰(zhàn)沒有找出具體是哪個操作引起的,今天繼續(xù)努力!
如果實在找不出,只能先卸載 .NET Framework 4.5,重新安裝 .NET Framework 4.0。
問題相關(guān)代碼
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 = "" }
);
}
出現(xiàn)問題的訪問路徑:根路徑與 ing/default.aspx,這兩個路徑訪問的都是實際的 .aspx 文件。