ASP.NET網站發佈時的那些坑,要小心了,為什麼網站發布後,每個頁面第一次打開都很卡? ASP.NET session 經常遺失如何解決?有一定的參考價值,有興趣的小夥伴可以參考一下
開發工具:VS2010,MVC4.0,SQLSERVER2008
伺服器:Windows server 2012,IIS8,SQLSERVER2012
##一、發布後,每個頁面第一次打開都很卡,50秒或更長,第二次打開就很快了
估計原因:編譯速度慢,但在有VS環境的機器上發布沒有這麼卡
解決方案:
使用高版本的VS,「在發布期間預編譯」;使用IIS8的Application Initialization功能1.使用VS2017「在發布期間預編譯」
#發佈時遇到一個報錯:
在應用程式層級之外使用註冊為allowDefinition='MachineToApplication' 的節是錯誤的。如果在 IIS 中沒有將虛擬目錄配置為應用程序,則可能導致此錯誤。
解決方法:發佈時註解web.config中的以下程式碼
##
<!--<authentication mode="Forms"> <forms loginUrl="~/Account/Login" timeout="2880" /> </authentication>-->2. 使用IIS8的Application Initialization功能ASP.NET網站第一次存取慢的解決方法
二、ASP.NET session 頻繁遺失問題
#問題現象:登入後30秒左右會話遺失,需要重新登入。 解決方法:ASP.NET有幾種會話狀態模式,預設為“InProc模式”,改為“StateServer模式”,問題解除。1. off模式
即關閉Session。 全站關閉Session可在Web.Config檔案中的2dc15ec6bc814c3aa45b55d017848bed節中寫入:2455e49983024f8ccf8b732f0adf21a62. InProc模式(預設模式)
若未在Web.config檔中設定SessionState Mode,預設為InProc模式。 如果要自訂InProc模式的參數,則需要寫入Web.config文件,例如:59b24c7a28b047e331953fbffedf4b2a public class SomeClass { }
4. SQLServer模式
使用SQL Server來保存Session,即使IIS重啟,Session仍然不會遺失。需要先建立ASPState資料庫。具體方法可上網查詢。 以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。以上是分享兩種ASP.NET網站發佈時的遇到的問題及解決方案的詳細內容。更多資訊請關注PHP中文網其他相關文章!