我在一台机器上测试集群和session复制是正常的,但是放到多台机器上就不行了,发现不了其他机器上的tomcat。 后来我用一个组播测试工具测过一次,我收不到组播源发出的信息。 
还用过一段java代码测试,也不行。 
这是那个java测试组播的代码。 
我收不到组播的信息。 public class MultiCastTest { 
public static void main(String[] args) throws Exception { 
// join a Multicast group and send the group salutations 
String msg = "Hello"; 
InetAddress group = InetAddress.getByName("224.0.0.8"); 
MulticastSocket s = new MulticastSocket(45564); 
s.joinGroup(group); 
DatagramPacket hi = new DatagramPacket(msg.getBytes(), msg.length(), 
group, 6789); 
System.out.println("sending..."); 
s.send(hi); 
System.out.println("sent and wait for receive."); // get their responses! 
byte[] buf = new byte[1000]; 
DatagramPacket recv = new DatagramPacket(buf, buf.length); 
s.receive(recv); 
System.out.println("received."); 
System.out.println(new String(recv.getData(), 16, recv.getLength())); // OK, I'm done talking - leave the group... 
s.leaveGroup(group); 
} } 
我看文档上说tomcat的集群是通过组播技术实现的,是不是路由器必须要支持IGMP协议才行? 
我现在也不知道路由器是不是支持IGMP协议,有没有什么办法测试一下?

解决方案 »

  1.   

    看看你apache上的配置,有没有配置对。
      

  2.   

    apache上的负载均衡和粘性session是正常的
      

  3.   

    apache上的负载均衡和粘性session是正常的
      

  4.   

    其实你可以这样测试一下第一次登陆,把登陆的tomcat中打印出来登陆信息,然后把打印登陆信息的那个tomcat关掉再访问一下,看看第二个tomcat中能做Seession存在的动作或者打印Session看看有没有赋值过来如果第二次打开的tomcat没有session,去追踪apache有没有配置对。这样就好了还有,在测试过程中不要让浏览器禁止cookie有的时候session赋值是通过cookie来实现的。
      

  5.   

    apache + jk 肯定没问题,不管是单台机器还是多台机器都是正常的。
    session我是通过filter打印的,每次请求过来都会打印。
    登陆后关闭打印登陆session的那个tomcat然后继续访问的话session就失效了,session没有复制过来。
    因为tomcat启动后就没有发现其他的tomcat,通过控制台打印的信息可以看出来。
      

  6.   

    apache上的负载均衡和粘性session是正常的