Chinaunix首页 | 论坛 | 博客
  • 博客访问: 827088
  • 博文数量: 190
  • 博客积分: 2991
  • 博客等级: 少校
  • 技术积分: 2400
  • 用 户 组: 普通用户
  • 注册时间: 2012-09-24 18:11
文章分类

全部博文(190)

文章存档

2015年(3)

2014年(1)

2013年(65)

2012年(121)

我的朋友

分类: C/C++

2013-02-21 18:11:25

本地搭建了一个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~

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