Tomcat的Session管理(二) - Session后台处理

简介: Tomcat的Session管理(二) - Session后台处理 Tomcat会开启一个后台线程每隔一段时间检查Session的有效性,这个线程是在Tomcat启动的时候当StardardEngine启动时随之启动的。
Tomcat的Session管理(二) - Session后台处理
Tomcat会开启一个后台线程每隔一段时间检查Session的有效性,这个线程是在Tomcat启动的时候当StardardEngine启动时随之启动的。可以参看StardardEngine的基类ContainerBase的#threadStart()方法:

Java代码 复制代码  收藏代码img_3d0b4cacdc5d213eebebbe13f1dc9910.gif
  1. protected void threadStart() {   
  2.     if (thread != null)   
  3.         return;   
  4.     if (backgroundProcessorDelay 0)   
  5.         return;   
  6.        
  7.     threadDone = false;   
  8.     String threadName = "ContainerBackgroundProcessor[" + toString() + "]";   
  9.     // 开启后台的监控线程   
  10.     thread = new Thread(new ContainerBackgroundProcessor(), threadName);   
  11.     thread.setDaemon(true);   
  12.     thread.start();   
  13.   
  14. }  
protected void threadStart() { if (thread != null) return; if (backgroundProcessorDelay
这个方法启动了一个ContainerBackgroundProcessor类的线程,这个类重写的#run()方法中包括了对Session的有效性监控。具体的细节就不详细陈述了。每隔一段时间,此线程就会启动一次并调用了ManageBase的#backgroundProcess()方法。其源代码如下:

Java代码 复制代码  收藏代码img_3d0b4cacdc5d213eebebbe13f1dc9910.gif
  1. public void backgroundProcess() {   
  2.     count = (count + 1) % proces***piresFrequency;   
  3.     if (count == 0)   
  4.         proces***pires();   
  5. }  
public void backgroundProcess() { count = (count + 1) % proces***piresFrequency; if (count == 0) proces***pires(); }

每隔一段时间就会调用proces***pires()方法去判断Session的有效性。

Java代码 复制代码  收藏代码img_3d0b4cacdc5d213eebebbe13f1dc9910.gif
  1. public void proces***pires() {   
  2.     // 现在的时间   
  3.     long timeNow = System.currentTimeMillis();   
  4.     // 所有的Session对象   
  5.     Session sessions[] = findSessions();   
  6.     int expireHere = 0;   
  7.   
  8.     if (log.isDebugEnabled())   
  9.         log.debug("Start expire sessions " + getName() + " at " + timeNow + " sessioncount "  
  10.                 + sessions.length);   
  11.     for (int i = 0; i 
  12.         // 判断并设定Session是否失效   
  13.         if (sessions[i] != null && !sessions[i].isValid()) {   
  14.             expireHere++;   
  15.         }   
  16.     }   
  17.     long timeEnd = System.currentTimeMillis();   
  18.     if (log.isDebugEnabled())   
  19.         log.debug("End expire sessions " + getName() + " processingTime " + (timeEnd - timeNow)   
  20.                 + " expired sessions: " + expireHere);   
  21.     processingTime += (timeEnd - timeNow);   
  22.   
  23. }  
public void proces***pires() { // 现在的时间 long timeNow = System.currentTimeMillis(); // 所有的Session对象 Session sessions[] = findSessions(); int expireHere = 0; if (log.isDebugEnabled()) log.debug("Start expire sessions " + getName() + " at " + timeNow + " sessioncount " + sessions.length); for (int i = 0; i
此方法最终调用了isValid()去判断和设定Session是否失效,源代码如下所示:

Java代码 复制代码  收藏代码img_3d0b4cacdc5d213eebebbe13f1dc9910.gif
  1. public boolean isValid() {   
  2.     // 是否过期   
  3.     if (this.expiring) {   
  4.         return true;   
  5.     }   
  6.     // 是否有效   
  7.     if (!this.isValid) {   
  8.         return false;   
  9.     }   
  10.     // 正在使用中并且访问数大于0   
  11.     if (ACTIVITY_CHECK && accessCount.get() > 0) {   
  12.         return true;   
  13.     }   
  14.   
  15.     if (maxInactiveInterval >= 0) {   
  16.         // 判断Session是否过期   
  17.         long timeNow = System.currentTimeMillis();   
  18.         int timeIdle = (int) ((timeNow - thisAccessedTime) / 1000L);   
  19.         if (timeIdle >= maxInactiveInterval) {   
  20.             // 设定Session过期   
  21.             expire(true);   
  22.         }   
  23.     }   
  24.   
  25.     return (this.isValid);   
  26. }  
目录
相关文章
|
存储 负载均衡 NoSQL
Tomcat 9.X(9.0.74)集群实现Session共享(基于redisson)
本文主要介绍了tomcat集群环境下基于redis+Redisson实现session共享,分享给大家,供广大从业者学习和参考。
12215 4
|
12月前
|
应用服务中间件 容器
Tomcat的Session过期处理策略
Tomcat的Session过期处理策略
103 0
|
应用服务中间件 容器
Tomcat设置session超时的几种方式
Tomcat设置session超时的几种方式
425 0
|
应用服务中间件 Windows
使用nssm管理tomcat服务操作步骤
使用nssm管理tomcat服务操作步骤
297 0
|
负载均衡 NoSQL Java
基于redis 的tomcat session 同步
这里我把Redis放在/XX/下,所以在该目录下执行下列命令: $ wget http://download.redis.io/releases/redis-3.2.1.tar.gz $ tar xzf redis-3.2.1.tar.gz $ cd redis-3.2.1 $ make
153 0
|
负载均衡 Java 应用服务中间件
tomcat集群下的session共享和负载均衡(memcache实现)
tomcat集群下的session共享和负载均衡(memcache实现)
119 0
|
负载均衡 NoSQL Java
tomcat集群下的session共享和负载均衡(redis实现)
tomcat集群下的session共享和负载均衡(redis实现)
256 0
|
NoSQL Java 应用服务中间件
tomcat集群使用redis实现session共享
tomcat集群使用redis实现session共享
276 0
|
存储 负载均衡 NoSQL
tomcat集群环境下如何保证session一致性
tomcat集群环境下如何保证session一致性
239 0
tomcat集群环境下如何保证session一致性
|
NoSQL 应用服务中间件 Redis
tomcat redis session共享的解决方案SessionListener不执行
tomcat redis session共享的解决方案SessionListener不执行