在 JXTA/JXSE 中加入现有的 PeerGroup

Join existing PeerGroup in JXTA/JXSE

我在使用 JXSE 时遇到问题。 假设我有一个会合点和一个边缘点,不在同一个本地网络上。

会合节点创建一个 peerGroup "test",并在该组中发布名为 "test advertisement"

的广告

假设我确定我的 EdgePeer 已连接到会合点。我可以使用 netpeerGroup.getRemoteAdvertisements().

找到现有组 "test"

但是我不知道如何加入这个现有的群组。我尝试了 netpeergroup.newGroup(testAdv),其中 testAdv = 创建的 peerGroupAdvertisement。

我在 "test" PeerGroup 中找不到广告 "test advertisement"。 但如果我在本地做所有这些事情,它就会起作用。也许我不明白 jxta 在本地和通过 Internet 工作的区别。

这里是创建或加入群组的代码:

public void addGroup(final String name) {
    ModuleImplAdvertisement mAdv = null;
    PeerGroup group = null;
    temp = null;

    defaultGroup.getDiscoveryService().getRemoteAdvertisements(null, DiscoveryService.GROUP, 
            "Name", name, 1, new DiscoveryListener() {

                @Override
                public void discoveryEvent(DiscoveryEvent event) {
                    Enumeration<Advertisement> advs = event.getResponse().getAdvertisements();
                    while(advs.hasMoreElements()) {
                        System.out.println("groupe found");
                        PeerGroupAdvertisement adv = (PeerGroupAdvertisement) advs.nextElement();
                        System.out.println("group name : " + adv.getName());
                        try {
                            temp = defaultGroup.newGroup(adv);
                            System.out.println("group joined");
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    }

                }
            });

    try {
        Thread.sleep(10000);
        System.out.println("waiting for group ...");
    } catch (InterruptedException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }

    if(temp == null) {
        try {
            System.out.println("creating new group ..");
            mAdv = defaultGroup.getAllPurposePeerGroupImplAdvertisement(); /* Getting the advertisement of implemented modules */
            temp = defaultGroup.newGroup(generatePeerGroupID(name), mAdv, name, name); /* creating & publishing the group */
            getDefaultGroup().getDiscoveryService().remotePublish(temp.getPeerGroupAdvertisement());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

终于找到问题了。您必须在每个组上启动 RendezVous 服务,而不仅仅是 netPeerGroup。

这就是为什么我的软件可以在本地运行但不能在 Internet 上运行的原因。