进程外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,则不引发该事件。 }
进程外Session保存和全局文件错误捕获的更多相关文章
- Asp.Net进程外Session(状态服务器Session、数据库Session)
介绍 我们知道,当浏览器关闭,或者网站重启的时候,会话就结束了.即Seesion就丢失了.(当Web.config配置文件改动,哪怕什么内容都不加,仅仅往配置文件中加一个空格都是改we.config变 ...
- 配置进程外Session 同时解决一个奇怪的BUG 因为SQLserver 服务器名不是默认的.或者localhost而引发的一系列问题
用公司的电脑学习如鹏网的视频,开发一个项目,用到了进程外session,因为公司电脑SQLServer 是2008 服务器名称是. 然后参考这篇文章进行设置进程外session 很顺利 完成了设置. ...
- 进程外session
进程外session A SqlServer 1.管理员身份运行cmd 2.更换目录 cd c:\Windows\Microsoft.NET\Framework\v4.0.30319> 3. ...
- Cookie和Session(session过程和设置进程外session)
cookie 和 session 的区别 cookie 是保存在客户端上的一种机制 而session 是保存在服务端的一种机制 cookie的理解: 打个简单的比方,一个人生病了去A医院看病,回 ...
- 第四节:框架前期准备篇之进程外Session的两种配置方式
一. 基本介绍 1. 背景:Asp.Net默认的Session机制是进程内,存储在服务器端内存中,有这么几个缺点: ①:既然存在内存中,空间有限,不能存储大数据量信息,数据量多的话Session会被挤 ...
- 配置进程外Session
配置进程外Session: (1)将服务器Session信息存储在进程外 <1> 首先,开启asp.net state 服务: 控制面板 -> 程序和功能 -&g ...
- 第十六节:Asp.Net Core中Session的使用、扩展、进程外Session
一. 简介 关于Session的原理可参照Asp.Net版本Session的文章,去查阅. 1. 普通用法 (1).通过Nuget引入[Microsoft.AspNetCore.Http]程序集,Co ...
- 探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)
其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...
- 学习笔记16_页面缓存/进程外Session
*页面缓存:适用于访问量较高的网站 <%@OutputCache Duration="15"//缓存15秒 VaryByParam='*' //请求的任何一处发生改变,缓存 ...
随机推荐
- jquery 分页 下拉框
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 【POJ】2165.Gunman
题解 把直线的斜率分解成二维,也就是随着z的增加x的增量和y的增量 我们发现一条合法直线向上移一点一定能碰到一条横线 知道了这条横线可以算出y的斜率 我们旋转一下,让这条横线碰到两条竖线,就可以算出x ...
- Bechmarksql
使用方法 1.配置JDK环境 JDK最好是1.5以上的版本 JAVA_HOME=/usr/java/jdk1.6.0_22 PATH=$PATH:$JAVA_HOME/bin 2.准备工作 把要测试的 ...
- Tuning Optimization
2017-02-22 在经过Trace的分析并重新优化之后 CPU: Intel(R) Xeon(R) CPU E5-2630 v2 @ 2.6GHz 24core 如上图,CPU使用率平均低于60% ...
- CentOS7的一些指令
hostnamectl --static set-hostname yuanxu#永久修改主机名 systemctl stop firewalld.service #停止firewall system ...
- 远程连接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 ...
- 第二波分析:德国是2018世界杯夺冠最大热门? Python数据分析来揭开神秘面纱… (附源代码)
2018年,世界杯小组赛已经在如火如荼的进行中.在上篇文章的基础上[2018世界杯:用Python分析热门夺冠球队],我们继续分析世界杯32强的实力情况,以期能够更进一步分析本次世界杯的夺冠热门球队. ...
- java main class not found
1.确保 所有jar都存在, 清理所有不存在的jar 2.确保src以外没有java类
- 文件哈希审计工具md5deep/hashdeep
文件哈希审计工具md5deep/hashdeep 在数据取证中,通常需要验证文件的哈希值,以判断文件是否已知好文件,或者文件是否被修改过.Kali Linux提供专用工具hashdeep.该工具的 ...
- 机器学习之路:python 特征降维 主成分分析 PCA
主成分分析: 降低特征维度的方法. 不会抛弃某一列特征, 而是利用线性代数的计算,将某一维度特征投影到其他维度上去, 尽量小的损失被投影的维度特征 api使用: estimator = PCA(n_c ...