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~

 

 

你可能感兴趣的:(session同步)