memcached做Session同步时失败的问题
本地搭建了一个nginx+两台tomcat+memcached的测试环境,一开始困扰在memcached的JAR包问题,实在是分散...全部搭建完毕后发现SESSION进行了同步,惊喜中...
当再次操作其他内容时候,页面突然跳转到登录页,一下子懵了,这是什么个情况...tomcat的输出日志显示SESSION是一样的,但就是需要重新登录。无奈之下开启远程调试,
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~