package com.yunling.mediacenter.server;
public class HelloWorld {
private PeerGroup netgroup = null;
private Enumeration ae = null; // 记录发现的对等体广告。
public static void main(String[] args) {
HelloWorld myapp = new HelloWorld();
myapp.startJxta();
System.exit(0);
}
public void startJxta() {
try {
netgroup = new NetPeerGroupFactory().getInterface();
} catch (PeerGroupException e) {
e.printStackTrace();
}
// 从NetPeerGroup获得发现服务
DiscoveryService hdisco = netgroup.getDiscoveryService();
ae = findPeerGroup(hdisco, "Name", "HelloWorld");
if (ae != null && ae.hasMoreElements()) {
System.out.println("找到HelloWorld对等组");
joinPeerGroup(netgroup, (PeerGroupAdvertisement) ae.nextElement());// 找到目标对等组,加入
System.out.println("加入HelloWorld对等组成功!!!");
} else {
System.out.println("没有找到HelloWorld对等组,则创建,在创建中......");
createNewPeerGroup(netgroup, "HelloWorld", "HelloWorld,Inc");// 没有找到目标对等组,创建
System.out.println("创建HelloWorld对等组成功!!!");
}
System.exit(-1);
}
private Enumeration findPeerGroup(DiscoveryService dis, String key,
String name) {
int count = 3; // 试图发现的最高次数
int timeout = 3000;
Enumeration advs = null;
// 循环直到我们发现helloWorld对等组或是直到我们达到了试图预期发现的次数。
while (count-- > 0) {
try {
// 第一次搜索对等体的本地缓存来查找helloWorld对等组通告。
// 通过NetPeerGroup组提供的发现服务发现"Name"属性为"helloWorld"的对等组
advs = dis.getLocalAdvertisements(DiscoveryService.GROUP, key,
name);
// 如果发现helloWorld对等组通告,该方法完成,退出循环。
if ((advs != null) && advs.hasMoreElements()) {
break;
}
// 如果我们没有在本地找到它,便发送发现远程请求。
// 参数依次为要查找的对等体ID,为空时不以此为发现条件;发现的通告类型,取值还有PEER,和ADV;
// 要发现的通告属性名称;属性取值;需获取的最大通告数量;发现监听器
dis.getRemoteAdvertisements(null, DiscoveryService.GROUP, key,
name, 1, null);
// 线程延时一下等待对等体內该发现请求。
try {
Thread.sleep(timeout);
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return advs;
}
// 如果不存在目标对等组,则创建目标对等组
private PeerGroup createNewPeerGroup(PeerGroup netpg, String name,
String desc) {
PeerGroup result = null;
try {
// 创建一个新的对等组helloWorld
// 通过NetPeerGroup获得一个一般对等组的通告。
ModuleImplAdvertisement implAdv = netpg
.getAllPurposePeerGroupImplAdvertisement();
// 通过NetPeerGroup创建一个新的对等组,JXTA会自行发布该对等组通告,
// 参数依次为对等组ID,通告,组名,描述
result = netpg.newGroup(IDFactory.newPeerGroupID(), implAdv, name,
desc);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
// 加入对等组
private PeerGroup joinPeerGroup(PeerGroup netpg,
PeerGroupAdvertisement pgAdv) {
PeerGroup result = null;
try {
// 加入该对等组,由于该通告已经发布,JXTA不会再行发布。
result = netpg.newGroup(pgAdv);
} catch (PeerGroupException e) {
e.printStackTrace();
}
return result;
}
}package com.yunling.mediacenter.server;
public class HelloWorld {
private PeerGroup netgroup = null;
private Enumeration ae = null; // 记录发现的对等体广告。
public static void main(String[] args) {
HelloWorld myapp = new HelloWorld();
myapp.startJxta();
System.exit(0);
}
public void startJxta() {
try {
netgroup = new NetPeerGroupFactory().getInterface();
} catch (PeerGroupException e) {
e.printStackTrace();
}
// 从NetPeerGroup获得发现服务
DiscoveryService hdisco = netgroup.getDiscoveryService();
ae = findPeerGroup(hdisco, "Name", "HelloWorld");
if (ae != null && ae.hasMoreElements()) {
System.out.println("找到HelloWorld对等组");
joinPeerGroup(netgroup, (PeerGroupAdvertisement) ae.nextElement());// 找到目标对等组,加入
System.out.println("加入HelloWorld对等组成功!!!");
} else {
System.out.println("没有找到HelloWorld对等组,则创建,在创建中......");
createNewPeerGroup(netgroup, "HelloWorld", "HelloWorld,Inc");// 没有找到目标对等组,创建
System.out.println("创建HelloWorld对等组成功!!!");
}
System.exit(-1);
}
private Enumeration findPeerGroup(DiscoveryService dis, String key,
String name) {
int count = 3; // 试图发现的最高次数
int timeout = 3000;
Enumeration advs = null;
// 循环直到我们发现helloWorld对等组或是直到我们达到了试图预期发现的次数。
while (count-- > 0) {
try {
// 第一次搜索对等体的本地缓存来查找helloWorld对等组通告。
// 通过NetPeerGroup组提供的发现服务发现"Name"属性为"helloWorld"的对等组
advs = dis.getLocalAdvertisements(DiscoveryService.GROUP, key,
name);
// 如果发现helloWorld对等组通告,该方法完成,退出循环。
if ((advs != null) && advs.hasMoreElements()) {
break;
}
// 如果我们没有在本地找到它,便发送发现远程请求。
// 参数依次为要查找的对等体ID,为空时不以此为发现条件;发现的通告类型,取值还有PEER,和ADV;
// 要发现的通告属性名称;属性取值;需获取的最大通告数量;发现监听器
dis.getRemoteAdvertisements(null, DiscoveryService.GROUP, key,
name, 1, null);
// 线程延时一下等待对等体內该发现请求。
try {
Thread.sleep(timeout);
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return advs;
}
// 如果不存在目标对等组,则创建目标对等组
private PeerGroup createNewPeerGroup(PeerGroup netpg, String name,
String desc) {
PeerGroup result = null;
try {
// 创建一个新的对等组helloWorld
// 通过NetPeerGroup获得一个一般对等组的通告。
ModuleImplAdvertisement implAdv = netpg
.getAllPurposePeerGroupImplAdvertisement();
// 通过NetPeerGroup创建一个新的对等组,JXTA会自行发布该对等组通告,
// 参数依次为对等组ID,通告,组名,描述
result = netpg.newGroup(IDFactory.newPeerGroupID(), implAdv, name,
desc);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
// 加入对等组
private PeerGroup joinPeerGroup(PeerGroup netpg,
PeerGroupAdvertisement pgAdv) {
PeerGroup result = null;
try {
// 加入该对等组,由于该通告已经发布,JXTA不会再行发布。
result = netpg.newGroup(pgAdv);
} catch (PeerGroupException e) {
e.printStackTrace();
}
return result;
}
}
分享到:
相关推荐
PassMark BurnInTest V5.3 Copyright (C) 1999-2008 PassMark Software All Rights Reserved http://www.passmark.com Overview ======== Passmark's BurnInTest is a software tool that allows all the major sub...
最好用的单元测试工具,除了这里你是找不到9.0版本的破解的。 ... 独立的版本破解: ... 把lic_client.jar复制到 ... c:\Program Files (x86)\Parasoft\Test\9.0\plugins\...这个是:plugins-c++Test For Visual Studio.7z
eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速工具eNetTest 网管内网单机测速...
c:\Program Files (x86)\Parasoft\C++test for Visual Studio\9.0\plugins\ 这个目录中 把plugins-Test for Virsual Studio.7z 中的文件覆盖到 c:\Program Files (x86)\Parasoft\Test for Visual Studio\9.0\...
Modeltest 使用说明 Modeltest 是一个选择核苷酸替代模型的软件,通过和 PAUP 配合使用,可以选择出合适的 MODEL,并同时计算出相关参数。下面是 Modeltest 的使用说明和相关知识点: 一、Modeltest 概述 * Model...
(speedtest服务器搭建教程) 本篇教程旨在指导读者搭建speedtest服务器,通过安装PHPStudy、配置WNMP和Nginx、下载并配置speedtest测速平台,实现本地测速功能。 一、 PHPStudy 安装和配置 PHPStudy 是一个集成...