加入JXTA / JXSE中的现有PeerGroup

时间:2015-06-05 10:31:39

标签: java p2p jxta

我在使用JXSE时遇到问题。 让我们说我有一个rendezVous对等体和一个边缘对等体,而不是在同一个本地网络上。

rendezVous对等体创建一个peerGroup" test",并在该组中发布一个名为" test advertise"

的广告

让我说我确信我的EdgePeer已连接到rendezVous对等端。我可以找到现有的小组" test"使用netpeerGroup.getRemoteAdvertisements()。

但我不知道如何加入这个现有的群体。我尝试了netpeergroup.newGroup(testAdv),testAdv =已建立的peerGroupAdvertisement。

我无法找到广告"测试广告"在"测试"对等组。 但如果我在本地做所有这些事情,它就有效。也许我不了解jxta在本地和互联网上如何运作的区别。

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

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();
        }
    }

1 个答案:

答案 0 :(得分:2)

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

这就是我的软件在本地工作但不在互联网上的原因。