进程外Session保存和全局文件错误捕获

 Session深入学习,进程外的Session

当用户登入页面跳转时候,我们会将用户登录信息保存在服务端一个键值对的Session(Session池)中。那么Session池又是在哪里呢

它最终默认存放的文件是一个叫做 aspnet_wp.exe的可执行程序中(做为一个辅助进程)。路径就在Framework/版本 下面。 它有一个缺点,容量有限!!

一旦Session池满了,存的数据太多了,这个aspnet_wp.exe程序就会重启,Session就会丢失!(一个微软官方的bug,不可修复)

什么叫服务呢

其实就是一个可执行的exe程序,只是它没有界面操作而已。

那怎么办呢

解决方案

1.进程外保存:

再也不担心网站的重启或者关闭丢失Seesion 不要再用这个aspnet_wp.exe保存session了,我们使用专门保存session的状态服务程序 aspnet_state.exe,默认端口42424。

此端口预留给Framework通信使用 。

2.SqlServer数据库保存:

不管是关闭网站重启网站,关闭状态服务都不会影响到Session的保存 将session存入aspnet数据库中。

必要的消耗:通信消耗,数据必要的属性:可序列化

 

Session是可设置保存位置的

如何做到进程外保存Session 利用状态服务

1.开启电脑状态服务 ASP.NET State Service

2.配置web.config文件

<system.web> 
<sessionState mode=""> 
</sessionState> 
<!-- mode Custom 自定义| 
   Inpoc 进程内的(默认)|
   Off 关闭不使用Session |
   SQLServer SQL保存 |
   StateServer 进程外(浏览器不可以关,因为SessionId是保存在客户端浏览器缓存Cookie中的)
--> <system.web>

默认端口42424是可以根据注册表更改的

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\aspnet_state\Parameters Port修改

修改后 配置文件一定要同步

<system.web> 
<sessionState mode="StateServer" stateConnectionString = "tcpip=localhost:42424"> 
</sessionState> 
<system.web> 

注意:如果需要将一个对象类保存在进程外的Session中,一定要标识这个类是可序列化的。[Serializable]

 

利用SQL保存Session

如果要使用 SQL 保存Session数据,首先要在Framework/v4.0.30319安装目录运行一个叫 aspnet_regsql.exe 的可运行程序。它是一个向导,它会自动在数据库创建一些必要的表。

然后执行InstallSqlState.sql或者InstallSqlStateTemplate.Sql 有好多个,分为临时存储,和持久化存储自己选择,

注意:需要使用SQLServerAgent服务--因为调度作业

再然后

配置web.config

<!-- 配置Session --> 
<system.web> <sessionState mode="SQLServer" > </sessionState> </system.web>

保存在数据库 ASPState 中,里面有两张表 ASPStateTempApplicaions (两列 AppId,AppName),ASPStateTempSessions

 

Global.asax 全局文件错误处理 

//当网站第一次被请求的时候运行         
void Application_Start(object sender, EventArgs e)         
{         
        //一般在这个方法中 做一些网站全局 的配置读取及初始化     
}        
 void Application_End(object sender, EventArgs e)     
{         
        //  在应用程序关闭时运行的代码    
}

// 在出现未处理的错误时运行的代码     
//一般可以用来做 错误日志     
void Application_Error(object sender, EventArgs e)     
{         
        HttpApplication app = sender as HttpApplication;         
        Exception ex = app.Context.Server.GetLastError();
        app.Context.Response.Redirect("06Err.aspx?err=" +app.Context.Server.UrlEncode(ex.Message));
        app.Context.Response.End();
        //app.Context.Response.Redirect("06Err.aspx");        
        //string logFile = app.Context.Server.MapPath("04Log.txt");         
        //System.IO.File.AppendAllText(logFile, ex.Message);     
}

void Session_Start(object sender, EventArgs e)     
{        
         // 在新会话启动时运行的代码    
}

void Session_End(object sender, EventArgs e)     
{        
        // 在会话结束时运行的代码。         
        // 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为         
        // InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer         
        // 或 SQLServer,则不引发该事件。

    }       

 

posted on 2014-03-17 10:01  Aidou_dream  阅读(406)  评论(0编辑  收藏  举报

导航