JXTA P2P编程技术例程一

JXTA P2P编程技术例程一

ID:47037154

大小:46.50 KB

页数:6页

时间:2019-07-03

JXTA P2P编程技术例程一_第1页
JXTA P2P编程技术例程一_第2页
JXTA P2P编程技术例程一_第3页
JXTA P2P编程技术例程一_第4页
JXTA P2P编程技术例程一_第5页
资源描述:

《JXTA P2P编程技术例程一》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、JXTAP2P编程技术例程(1)作者:yxiong2000

2、日期:2004-07-30

3、字体:大中小在这个例子中,我们会设计和编写一个分布式JXTA应用,可以解决并行计算问题。我们将用一个反复使用的形式建立这个应用,在每步中扩大它的能力和使用到的API集。这些原代码只能覆盖最重要的部分,需要全部代码可以到网站上查询一些大型计算问题的子集可以用并行的方法解决。一个工作的并行执行意味着你可以将一个问题分解为几个小的子问题,这些子问题又可以被同时的被执行。当一个子问题结束后,它将返回自己的结果到主程序,主程序将这些返回的小结果组合为更大的答案

4、。举个例子,考虑将任何2个整数间的质数列出来的工作。质数就是那些只能被它自己和1整除的自然数。那些可以被1和其他比自己小的数整除的叫合数。因此,最简单的方法产生一个质数列表就是在自然数列表中消除所有的合数,剩余的就是质数了。这个方法反复消除一系列自然数中的合数。它将列表中的每个数都用2到它的平方根去除。如果任何一个数被这样除了之后没有余数,那么这个数就是合数,并且对它作上标记。当这些反复(工作)结束了之后,所有的被标记的数将被消除,剩下的就是质数了。但是如果是一个很长的列表,有数百万的长度,那么我们将它分为几个小一点的列表,然后对每个列

5、表执行上述方法。每个子计算被分发到网络上不同的机器去执行,充分利用分布的计算资源。质数的查询是这些可以被并行分解的大型问题集中的一个,现在流行的P2P风格的软件有不少,比如SETI@HOME工程,它的目标是对来自外太空的信号解码,寻找外星智能生物,类似的工程还有让用户共享出他们空闲CPU的资源去模拟蛋白质的折叠或者解码DNA串。在这个应用中,主程序将向用户请求2个数,然后产生一个在2数之间包含所以质数的数列。这个主程序将首先在JXTA网络上尝试找到提供质数查询服务的的其他peer,然后将列表的片段分发给它们去执行。当一个peer完成了它

6、的那一部分,它将返回这个片段中质数的数组。为了这样的分配能够进行,我们要让所有peer能够在网络上通告(advertise)它具备质数查询的能力以让其他的peer可以找到并连接它。JXTAApplicationDesign可能这个应用最不平常的一个方面就是,每个peer既扮演主程序(masterprocess)的角色和一个从属程序的角色(slave),也有可能一个从属程序还要决定是否进一步的分解这个问题到的子任务。这种服务模式/客户模式操作是P2P程序设计的实质。我们将它定义为SM/CM操作消息定义当我们设计一个JXTA程序的时候,我们

7、必须忍受JXTA是一个基于消息的系统:2个peer中的主要协议(contract)主要是通过消息。这样,设计程序的第一个工作就是定义消息传递。在这个质数查询应用中,一个peer传递一条包含2个边界数的消息给另外一个peer,接受的一方计算在这2个边界数中的质数,返回到以前的peernet.jxta.endpoint.Message类概括出一个消息的感念,它允许赋予任何一个消息集一个键(KEY)。我们将在下表中用键-值来表示这个类的实例Table16.1.RequestMessageKeyValueServiceConstants.LOW

8、_INTLowerboundaryofthe(sub)listServiceConstants.HIGH_INTUpperboundaryofthe(sub)listTable16.2.ResponseMessageKeyValueServiceConstants.LOW_INTLowerboundaryofthe(sub)listServiceConstants.HIGH_INTUpperboundaryofthe(sub)listServiceConstants.PRIMELISTAstringcontainingallprimes

9、betweentheboundsofthelist.Theprimesareseparatedby;characters.服务的定义与发现下一步,我们必须定义一个让主程序找到从属程序的方法,换句话说,我们比如让peer预先了解到提供这个服务的其他peer。就象早先提及的那样,一个JXTA服务是用它的module类和specification定义的。因此,我们将为这个质数查询服务module和specification定义一个通告.然后让一个peer提供一个让这些通告在JXTA网络中传播的服务。这个质数查询module类将采用JXTACL

10、ASS:com.sams.p2p.primecruncher这个名字,module的spec将采用thenameJXTASPEC:com.sams.p2p.primecruncher这个名字主程序将用这个名

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。