session 的钝化和活化 | 学习笔记

简介: 快速学习 session 的钝化和活化。

开发者学堂课程【Servlet 入门:session 的钝化和活化】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/38/detail/892


session 的钝化和活化


内容介绍

一、什么是 session 的钝化和活化

二、示例步骤

 

 

一、什么是 session 的钝化和活化

假设我们在淘宝中用户过多的时候,虽然 session 没有下限,但 session 的数量就会不断增多。

之后就会导致内存无法承受,此时就会有一些 session 长时间都没有活动。

服务器启动时就会将这些很久没有活动的 session 放到硬盘上,让内存给空出来。

就会使得很多的session被保存到硬盘上以此来空出内存。而即便之后需要再次访问 ession,它就会再次从硬盘中将 session给放回来使用。这样用户就不会感觉到自己掉线了。

这个过程就是 session 的钝化和活化。

而钝化和活化最终都是把 session 保存到硬盘中,再从硬盘中回到内存中。

但是他们发生的时间点不一样。一个是关闭和启动服务器,一个是没有关闭和启动服务器就完成了。

1.png

注意,因为钝化和活化 session,其实就是使用序列化和反序列化技术把 session 从内存保存到硬盘,和把 session从硬盘加载到内存。

这说明如果 Person 类没有实现 Serializable, 接口,那么当 session 钝化时就不会钝化Person,而是把 Person session 中移除再钝化!这也说明 session 活化后, session 中就不在有 Person 对象了。

 

二、示例步骤

先不管 HittpSessionActivationListener 监听器接口,先来配置 Tomcat 钝化 session 的参数,把 下面配嚣文件放到 tomcatlconflcatalinaVocalhost目录下!文件名称为项目名称。

"org.apache.catalina.session.PresistentManger"(maxIdl9swap="1")[11]

"org.apache.catalina.session.FileStore"(directory="mysession")/>[12]

访问项目的 index.jsp 页面,这会使 Tomcat 创建 Session 对象,然后等待一分钟

Tomcat\work\Catalina\localhost\istenermysession.目录下是否会产生文件,如果产生了,说明钝化 session 的配置成功了,可以开始下一步了。

打开 context.xml 把代码添加到35行代码进去,在此处表示对所有代码都生效。

1.png2.png接下来,我们启动。使用 a.jsp 保存数据。b.jsp 输出数据。1.png2.png

之后再打开 mysession 文件夹后耐心等待一段时间后就可以看见以一个 session 一个存储的形式展现出来。

文件名是 sessionID。扩展名是 .session 。跟刚才的序列化相比,序列化是sessions.ser 但现在是 SessinonID 为名称。1.png

显示出来的效果如图为已经钝化的 session ,但是即便将其活化之后该文件也不会消失。并且它所占的内存极小,且不会被加载文件。

2.png

1.png然后我们再打开一个窗口试一下会发现,几乎根本感觉不到 session 的钝化和活化。

钝化就是将其保存到上面的文件中,活化就是将其加载出来。1.png

[注:6]如果 session 1分钟内没有使用那么 Tomcat 就会钝化它


session 序列化到 Tomcat\work\Catalina\Localhost\listener\mysession 目录下

相关文章
|
7月前
|
存储 开发者
Session 使用详解
Session 使用详解
115 1
|
存储 安全 NoSQL
97 # session
97 # session
45 0
|
26天前
|
存储 安全 PHP
24 Session
路老师在知乎上分享了PHP语言的知识,帮助大家入门并深入了解PHP。本文重点讲解了Session管理,包括Session的基本概念、工作原理、功能、创建会话、存储和读取会话数据,以及删除会话的方法。通过这些内容,读者可以更好地理解和应用Session技术。
28 1
|
7月前
|
存储
|
存储 开发框架 安全
session
session
125 0
|
SQL Oracle 关系型数据库
|
关系型数据库 Linux