加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 应用程序池循环如何影响ASP Net会话状态?

发布时间:2020-12-15 20:56:36 所属栏目:asp.Net 来源:网络整理
导读:我知道,当应用程序池被回收时,会启动一个新的工作进程,但我对在此过程中如何处理过期和有效会话感到困惑?传递给新的工作进程线程哪些被淘汰?它会做什么: 用户A的会话已过期 用户B的会话有效 在回收之后,当用户A和用户B将要求他们的会话状态是什么时? 解
我知道,当应用程序池被回收时,会启动一个新的工作进程,但我对在此过程中如何处理过期和有效会话感到困惑?传递给新的工作进程线程哪些被淘汰?它会做什么:

>用户A的会话已过期
>用户B的会话有效

在回收之后,当用户A和用户B将要求他们的会话状态是什么时?

解决方法

如果您有一个Web服务器,并且您已使用默认的InProc模式进行SessionState持久性,那么您在服务器代码中添加到会话的Dictionary中的任何数据都将在应用程序池回收期间丢失 – 在回收之后,当您的代码接下来访问SessionState字典中的条目时,它将返回null.

如果跨负载均衡器有多个Web服务器,会话状态错误地配置为InProc,并且用户返回到不同的服务器(即没有粘性路由),则会发生类似情况.

(存储在浏览器上的会话状态cookie可能仍有效几分钟).

允许会话状态“存活”应用程序池回收,服务器崩溃或跨越服务器场的方式是保留存储在SessionState中的数据,以便服务器(或多个服务器)可以在用户的??时候再次检索数据会话返回.最简单的方法是使用out of the box解决方案之一,即单独的StateServer进程,或在SqlServer数据库中存储状态.自定义持久性也是一种选择.

一个警告 – 请注意,您在“进程外”模式下存储的任何数据(如StateServer或SqlServer)都需要可序列化 – 当您切换出InProc时,这可能是一个重大变化.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读