加入收藏 | 设为首页 | 会员中心 | 我要投稿 南平站长网 (https://www.0599zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长资讯 > 外闻 > 正文

Tomcat 中的 Session 和 Cookie的爱恨情仇

发布时间:2019-05-16 07:14:49 所属栏目:外闻 来源:顿悟源码
导读:副标题#e# HTTP 是一种无状态通信协议,每个请求之间相互独立,服务器不能识别曾经来过的请求。而对于 Web 应用,它的活动都是依赖某个状态的,比如用户登录,此时使用 HTTP 就需要它在一次登录请求后,有为后续请求提供已登录信息的能力。 解决办法就是使

一个 Web 应用对应一个会话管理器,也就是说 StandardContext 内部有一个 Manager 实例。每个容器组件都会启动一个后台线程,周期的调用自身以及内部组件的 backgroundProcess() 方法,Manager 后台处理就是检查 Session 是否过期。

检查的逻辑是,获取所有 session 使用它的 isValid 判断是否过期,代码如下:

  1. public boolean isValid() { 
  2.   ... 
  3.   // 是否检查是否活动,默认 false 
  4.   if (ACTIVITY_CHECK && accessCount.get() > 0) { 
  5.     return true; 
  6.   } 
  7.   // 检查时间是否过期 
  8.   if (maxInactiveInterval >= 0) {  
  9.     long timeNow = System.currentTimeMillis(); 
  10.     int timeIdle = (int) ((timeNow - thisAccessedTime) / 1000L); 
  11.     if (timeIdle >= maxInactiveInterval) { 
  12.       // 如果过期,执行一些内部处理 
  13.       // 主要是通知对过期事件感兴趣的 listeners 
  14.       expire(true); 
  15.     } 
  16.   } // 复数永不过期 
  17.   return (this.isValid); 

3.3 Session 持久化

持久化就是把内存中活动的 Session 对象,序列化到文件,或者存储到一个数据库中。如果会话管理组件符合并启用了持久化功能,那么就会在它生命周期事件 stop 方法中执行存储;在 start 方法中执行加载。

持久化到文件,StandardManager 也提供了持久化到文件的功能,它会把 session 池中活动的会话全部写入到CATALINA_HOME/work/Catalina///SESSIONS.ser文件中,代码在它的 doUnload 方法中。

FileStore 也提供了持久化到文件的功能,与 StandardManager 的区别是,它会把每个会话写入到单个文件中,以 .session 命名。

持久化到数据库,使用以下 SQL,分别把 session 相关数据存储到一个表中,包括序列化后的二进制数据,表字段信息如下:

  1. create table tomcat_sessions ( 
  2.   session_id     varchar(100) not null primary key, 
  3.   valid_session  char(1) not null, -- 是否有效 
  4.   max_inactive   int not null,-- 最大有效时间 
  5.   last_access    bigint not null, -- 最后访问时间 
  6.   app_name       varchar(255), -- 应用名,格式为 /Engine/Host/Context 
  7.   session_data   mediumblob, -- 二进制数据 
  8.   KEY kapp_name(app_name) 
  9. ); 

注意:需要把数据库驱动程序的 jar 文件,放到 $CATALINA_HOME/lib 目录中,以便让 Tomcat 内部的类加载器可见。

4. 小结

本文简单分析了 Tomcat 对 Session 的管理,当然了忽略的很多细节,有兴趣的可以深入源码,后续将会对 Tomcat 集群 Session 的实现进行分析。

(编辑:南平站长网)

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

热点阅读