本地搭建了一个nginx+两台tomcat+memcached的测试环境,一开始困扰在memcached的JAR包问题,实在是分散...全部搭建完毕后发现SESSION进行了同步,惊喜中...
当再次操作其他内容时候,页面突然跳转到登录页,一下子懵了,这是什么个情况...tomcat的输出日志显示SESSION是一样的,但就是需要重新登录。无奈之下开启远程调试,
Java代码:
-
HttpSession session = request.getSession(false);
-
if (session != null && map.containsKey(session.getId()) && map.get(session.getId()).getAdminName() != null) {
-
return invocation.invoke();
-
} else {
-
System.out.println(session.getId());
-
System.out.println(session != null);
-
System.out.println(map.containsKey(session.getId()));
-
System.out.println(map.get(session.getId()).getAdminName());
-
System.out.println(map.get(session.getId()).getAdminName() != null);
-
LogRecorder.record("检测到用户Session超时!", true);
-
return "timeout";
-
}
最后查明:SESSION超时判定多了一个用户名判断,即判定SESSION不为空时还要判断MAP中是否存在用户名,因为放入MAP不一定就是判断SESSION超时的那台tomcat,所以...悲剧发生了。经过修改后,不验证用户名了,感觉也没啥用...一切正常。
原文参考自站长网:
试验了一下关闭其中一台tomcat,重新启动,SESSION会同步过来,OK~
阅读(1030) | 评论(0) | 转发(1) |