标签:网站 image top 依赖 进程 版本 状态模式 pre order
开发工具:VS2010,MVC4.0,SQLSERVER2008
服务器:Windows server 2012,IIS8,SQLSERVER2012
估计原因:编译速度慢,但在有VS环境的机器上发布没有这么卡
解决办法:
发布时遇到一个报错:
在应用程序级别之外使用注册为 allowDefinition=‘MachineToApplication‘ 的节是错误的。如果在 IIS 中没有将虚拟目录配置为应用程序,则可能导致此错误。
解决办法:发布时注释web.config中的以下代码
<!--<authentication mode="Forms"> <forms loginUrl="~/Account/Login" timeout="2880" /> </authentication>-->
http://jingyan.baidu.com/article/c843ea0bb6c13877931e4a2e.html
问题现象:登录后30秒左右会话丢失,需要重新登录。
解决办法:ASP.NET有几种会话状态模式,默认为“InProc模式”,改为“StateServer模式”,问题解除
即关闭Session。
全站关闭Session可在Web.Config文件中的<system.web>节中写入:
<sessionState mode="off">
要在某个页面上关闭Session,可在页面上添加:
<%@ Page EnableSessionState="false" %>
如果未在Web.config文件中配置SessionState Mode,默认即是InProc模式。
如果要定制InProc模式的参数,需要写入Web.config文件,例如:
<sessionState mode="InProc" cookieless="false" timeout="20" />
cookieless设置是否允许不使用Cookie,timeout设置超时时间,单位为分钟。
InProc模式依赖于 ASP.NET进程, 当IIS进程崩溃或者重启时,保存在进程中的会话状态会丢失。
StateServer模式是将会话数据存储到单独的内存缓冲区中,由一个Windows服务“ASP.NET State Service ”(需要在windows服务中开启)来控制这个缓冲区,需要设置stateConnectionString:
<sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424" timeout="20" />
StateServer模式的优点是独立于IIS进程,IIS应用程序的重启不影响会话数据。
使用SQL Server来保存Session,即使IIS重启,Session仍然不会丢失。需要先创建ASPState数据库。具体方法可在网上查询。
标签:网站 image top 依赖 进程 版本 状态模式 pre order
原文地址:http://www.cnblogs.com/tuty/p/6664279.html