1

我正在尝试使用 TCP 传输配置 Infinispan。

如果TCPPING.initialHosts我将所有潜在集群节点的列表放入其中,则集群根本没有连接 - 大约有 15 个潜在节点,其中大多数是死的,通常只有 2 或 3 个还活着。

但是,如果在TCPPING.initialHosts我只列出 2-3 个主机的列表中,则集群创建成功。

我做错了什么?

更新:据我在日志和堆栈跟踪中看到,活动节点之间的连接已创建并且节点交换一些消息。然而,集群仍未形成。

更新:这是创建的代码JChannel

    JChannel ch = new JChannel(false);
    ProtocolStack stack = new ProtocolStack();
    ch.setProtocolStack(stack);

    // TCPPING is responsible for discovery
    TCPPING tcpping = new TCPPING();
    List<IpAddress> initial_hosts = ... // get lists of hosts, list can be quite big
    tcpping.setInitialHosts(initial_hosts);
    tcpping.setErgonomics(false);
    tcpping.setPortRange(0);
    tcpping.setNumInitialMembers(3);

    TCP tcp = new TCP();
    tcp.setBindAddress(InetAddress.getByName(server.getHostName()));
    tcp.setBindPort(server.getPort());
    tcp.setThreadPoolMaxThreads(30);
    tcp.setOOBThreadPoolMaxThreads(30);

    NAKACK nakack = new NAKACK();
    nakack.setUseMcastXmit(false);
    nakack.setDiscardDeliveredMsgs(false);

    MERGE2 merge = new MERGE2();

    RSVP rsvp = new RSVP();
    rsvp.setValue("timeout", 60 * 1000);
    rsvp.setValue("resend_interval", 500);
    rsvp.setValue("ack_on_delivery", false);

    stack
        .addProtocol(tcp)
        .addProtocol(tcpping)
        .addProtocol(merge)
        .addProtocol(new FD_SOCK())
        .addProtocol(new FD())
        .addProtocol(new VERIFY_SUSPECT())
        .addProtocol(nakack)
        .addProtocol(new UNICAST2())
        .addProtocol(new STABLE())
        .addProtocol(new GMS())
        .addProtocol(new UFC())
        .addProtocol(new MFC())
        .addProtocol(new FRAG2())
        .addProtocol(rsvp);
    stack.init();

    return ch;
4

1 回答 1

4

可能发现阶段花费的时间太长,因为 JGroups 尝试与 15 台主机建立连接,但其中只有 2-3 台还活着。我建议将 TCP.scok_conn_timeout 设置为较低的值(200?),以便我们从连接返回到最多 200 毫秒后关闭的主机。也许 GMS.join_timeout 需要增加,TCPPING.timeout 也是如此。它们应该高于最长的发现阶段。

于 2013-01-24T08:23:18.023 回答