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,则不引发该事件。 }

进程外Session保存和全局文件错误捕获的更多相关文章

  1. Asp.Net进程外Session(状态服务器Session、数据库Session)

    介绍 我们知道,当浏览器关闭,或者网站重启的时候,会话就结束了.即Seesion就丢失了.(当Web.config配置文件改动,哪怕什么内容都不加,仅仅往配置文件中加一个空格都是改we.config变 ...

  2. 配置进程外Session 同时解决一个奇怪的BUG 因为SQLserver 服务器名不是默认的.或者localhost而引发的一系列问题

    用公司的电脑学习如鹏网的视频,开发一个项目,用到了进程外session,因为公司电脑SQLServer 是2008 服务器名称是.  然后参考这篇文章进行设置进程外session 很顺利 完成了设置. ...

  3. 进程外session

    进程外session A  SqlServer 1.管理员身份运行cmd 2.更换目录  cd c:\Windows\Microsoft.NET\Framework\v4.0.30319> 3. ...

  4. Cookie和Session(session过程和设置进程外session)

    cookie 和  session 的区别 cookie 是保存在客户端上的一种机制   而session 是保存在服务端的一种机制 cookie的理解: 打个简单的比方,一个人生病了去A医院看病,回 ...

  5. 第四节:框架前期准备篇之进程外Session的两种配置方式

    一. 基本介绍 1. 背景:Asp.Net默认的Session机制是进程内,存储在服务器端内存中,有这么几个缺点: ①:既然存在内存中,空间有限,不能存储大数据量信息,数据量多的话Session会被挤 ...

  6. 配置进程外Session

    配置进程外Session: (1)将服务器Session信息存储在进程外           <1> 首先,开启asp.net state 服务: 控制面板 -> 程序和功能 -&g ...

  7. 第十六节:Asp.Net Core中Session的使用、扩展、进程外Session

    一. 简介 关于Session的原理可参照Asp.Net版本Session的文章,去查阅. 1. 普通用法 (1).通过Nuget引入[Microsoft.AspNetCore.Http]程序集,Co ...

  8. 探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)

    其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...

  9. 学习笔记16_页面缓存/进程外Session

    *页面缓存:适用于访问量较高的网站 <%@OutputCache Duration="15"//缓存15秒  VaryByParam='*' //请求的任何一处发生改变,缓存 ...

随机推荐

  1. jquery 分页 下拉框

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. 【POJ】2165.Gunman

    题解 把直线的斜率分解成二维,也就是随着z的增加x的增量和y的增量 我们发现一条合法直线向上移一点一定能碰到一条横线 知道了这条横线可以算出y的斜率 我们旋转一下,让这条横线碰到两条竖线,就可以算出x ...

  3. Bechmarksql

    使用方法 1.配置JDK环境 JDK最好是1.5以上的版本 JAVA_HOME=/usr/java/jdk1.6.0_22 PATH=$PATH:$JAVA_HOME/bin 2.准备工作 把要测试的 ...

  4. Tuning Optimization

    2017-02-22 在经过Trace的分析并重新优化之后 CPU: Intel(R) Xeon(R) CPU E5-2630 v2 @ 2.6GHz 24core 如上图,CPU使用率平均低于60% ...

  5. CentOS7的一些指令

    hostnamectl --static set-hostname yuanxu#永久修改主机名 systemctl stop firewalld.service #停止firewall system ...

  6. 远程连接mysql root账号报错:2003-can't connect to MYSQL serve(转)

    远程连接mysql root账号报错:2003-can't connect to MYSQL serve 1.远程连接Linux系统,登录数据库:mysql -uroot -p(密码) 2.修改roo ...

  7. 第二波分析:德国是2018世界杯夺冠最大热门? Python数据分析来揭开神秘面纱… (附源代码)

    2018年,世界杯小组赛已经在如火如荼的进行中.在上篇文章的基础上[2018世界杯:用Python分析热门夺冠球队],我们继续分析世界杯32强的实力情况,以期能够更进一步分析本次世界杯的夺冠热门球队. ...

  8. java main class not found

    1.确保 所有jar都存在, 清理所有不存在的jar 2.确保src以外没有java类

  9. 文件哈希审计工具md5deep/hashdeep

    文件哈希审计工具md5deep/hashdeep   在数据取证中,通常需要验证文件的哈希值,以判断文件是否已知好文件,或者文件是否被修改过.Kali Linux提供专用工具hashdeep.该工具的 ...

  10. 机器学习之路:python 特征降维 主成分分析 PCA

    主成分分析: 降低特征维度的方法. 不会抛弃某一列特征, 而是利用线性代数的计算,将某一维度特征投影到其他维度上去, 尽量小的损失被投影的维度特征 api使用: estimator = PCA(n_c ...