Chinaunix首页 | 论坛 | 博客
  • 博客访问: 524650
  • 博文数量: 469
  • 博客积分: 50
  • 博客等级: 民兵
  • 技术积分: 1495
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-15 21:04
文章分类

全部博文(469)

文章存档

2015年(81)

2014年(125)

2013年(261)

2012年(2)

分类: C/C++

2013-08-27 11:53:09

本地搭建了一个nginx+两台tomcat+memcached的测试环境,一开始困扰在memcached的JAR包问题,实在是分散...全部搭建完毕后发现SESSION进行了同步,惊喜中...

 

当再次操作其他内容时候,页面突然跳转到登录页,一下子懵了,这是什么个情况...tomcat的输出日志显示SESSION是一样的,但就是需要重新登录。无奈之下开启远程调试,

Java代码:  
  1. HttpSession session = request.getSession(false);  
  2.             if (session != null && map.containsKey(session.getId()) && map.get(session.getId()).getAdminName() != null) {  
  3.                 return invocation.invoke();  
  4.             } else {  
  5.                 System.out.println(session.getId());  
  6.                 System.out.println(session != null);  
  7.                 System.out.println(map.containsKey(session.getId()));  
  8.                 System.out.println(map.get(session.getId()).getAdminName());  
  9.                 System.out.println(map.get(session.getId()).getAdminName() != null);  
  10.                 LogRecorder.record("检测到用户Session超时!"true);  
  11.                 return "timeout";  
  12.             }  

 

最后查明:SESSION超时判定多了一个用户名判断,即判定SESSION不为空时还要判断MAP中是否存在用户名,因为放入MAP不一定就是判断SESSION超时的那台tomcat,所以...悲剧发生了。经过修改后,不验证用户名了,感觉也没啥用...一切正常。

 原文参考自站长网:

试验了一下关闭其中一台tomcat,重新启动,SESSION会同步过来,OK~

阅读(627) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~