本文主要是介绍JXTA简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前段时间做的毕业设计借助了Sun公司支持的开源JXTA项目,却一直未曾对这部分的学习进行一定的总结,今儿闲来无事,便想弥补一下。
1.JXTA项目简述
JXTA是Sun公司为解决先前开发P2P系统没有统一标准而提出的开发P2P应用的通用平台。JXTA定义了一组通用标准化协议,用于现有Internet和非IP网络基础上建立一个虚拟的P2P网络,实现结点间的通信。简单的说,JXTA是一个具有一组支持P2P应用程序的标准的框架,是一种点对点网络平台。
JXTA由三个层次组成:
1)平台----包含了服务使用的核心功能。
2)服务----提供了对JXTA协议的访问接口。
3)应用----基于JXTA服务开发的各种应用程序。
因为JXTA项目诞生的背景,JXTA项目的目标是实现平台独立于操作系统实现,独立于编程语言实现(目前只有java和C语言两种实现),为P2P应用程序提供服务和基础设施。本质上来说,就是支持任何设备上的点对点通信。
2.JXTA相关概念
这里介绍的部分概念不单单属于JXTA技术本身,在其他技术中也有相应的定义,这里重点介绍JXTA技术独有的特性。
(1)对等体
一个对等体是实现了一种或多种JXTA协议的网络实体。对等体可以存在于传感器、手机、个人数字助理、PC机、服务器以及超级计算机之上。每个对等体是独立存在的,并能与其他对等体实现异步通信,其由PeerID所唯一的标识。JXTA协议可使用任何可用的网络接口实现对等体间的通信,每个接口被通告为一个唯一地标识该接口的对等体端点(Peer Endpoint)。两个对等体之间通过对等体端点建立直接的点对点连接。相互通信的对等体间不一定直接连接,采用一些中间节点来路由那些因为各对等体处于不同物理网络或因配置管理不能直接到达的消息。对等体通过对等组进行管理,即对等体间可配置为在网络中能彼此发现而建立暂时或持续的关系。
JXTA对等体能被划分成三种主要类型:
Ø 最小边缘对等体(Minimal-EdgePeers):这类对等体仅仅实现必须的JXTA核心服务,可能需要其他对等体作为其代理实现其他非核心服务以帮助其完全加入一个JXTA网络。典型的最小边缘对等体包括传感器设备和家庭自动化设备。
Ø 具有完整特性的边缘对等体(Full-EdgePeer):这类对等体实现了全部核心和标准的JXTA服务,能够参与到全部的JXTA网络中。其构成了JXTA网络中的绝大多数对等体,主要包括:PC机,服务器等
Ø 超级对等体(super peer):这类对等体实现并提供资源以支持一个JXTA网络的调度与操作。这里有三种核心的JXTA超对等体功能:
①中继对等体(Relay):用于在两个因防火墙或NAT而不能直接建立网 络连接的对等体之间存储和转发消息。仅仅那些不能与其他对等体建立连接的对等体需要一个中继。
②集合点(Rendezvous):用于维护全局的通告索引,并帮助边缘对等体和代理对等体实现通告查询,同时也处理消息的广播。
③代理对等体(Proxy):最小边缘对等体需借助其使用JXTA网络功能。代理对等体为最小边缘对等体翻译并概括请求,响应查询,提供支撑功能。
(2) 对等组
对等组是共享资源和服务的对等体的集合,由PeerGroupID唯一的标识。逻辑上,任何对等体都可以任意加入多个不同类型的对等组,一个物理网络可以包括多个对等组,一个对等组可以跨越多个物理网络。当然,启动JXTA时,所有的对等体都加入到NetPeerGroup对等组中。
一个对等组提供多种对等组服务,同一对等组中的任意两个对等体正是通过对等组服务实现直接交互。
(3)管道
管道是在JXTA环境中建立的虚拟通信通道,用于在服务和应用之间发送消息。管道提供了一种基于对等体端点的虚拟抽象,实现了与对等体位置的物理无关性。管道可以连接一个或多个端点,假定在每个端点都有能独立用于收发、管理信息队列和信息流。管道根据在两端作用的不同被称为输出管道(OutputPipe,接收数据对等体那一端)和输入管道(InputPipe,发送数据对等体那一端)。
管道通过管道通告来发布和发现,一个管道ID唯一标识一个管道。管道被解析器在系统运行时动态绑定到对等体端点,使用这种管道抽象,服务和应用可以实现透明的失效恢复,通过从一个失效的物理对等体端点过渡到另外一个可用的对等体端点来避免服务或对等体失效。我们也可以利用该抽象来实现对一个新发布的服务实例进行访问。管道的绑定过程由查找和连接(连接可以实现一个管道连接到多个端点)两步构成。
总的来说,管道是一个逻辑的抽象概念,从对等体的角度看,管道隐藏了网络协议和网络拓扑结构的复杂性。对等体只需要发布其管道通告和获取其他对等体的管道通告,使用核心管道服务去解析这些通告所代表的底层网络连接。因此,对等体只需要读取和解释他们通过管道发送的消息:即只关心通信的内容,而不关心通信的方式。
管道可以被划分成以下三种类型:
Ø 点到点类型:点到点的管道连接到两个不同的Peer.可以使用多个起网关作用的Peer来创建连接。
Ø 传播类型:将一个Peer连接到多个目标Peer.
Ø 安全点到点类型:提供一个安全可靠的通信渠道。
现有的JXTA API中都有其他通信方式,如JxtaSocket,JxtaBiDiPipe等其实是在内部封装了核心管道服务。
(4)通告
一个通告即是一个XML文档,用于描述JXTA的消息,Peer,对等组,管道,或者服务等。换句话说,JXTA使用通告表示所有的网络资源。
JXTA定义了一下通告类型:
Ø 对等体通告:描述对等体资源,以使得其他对等体可以获取对等体信息(名称,ID,可用端点及一些运行属性)。
Ø 对等组通告:描述对等组特定资源,以使得对等体获取组信息,从而加入对等组。
Ø 管道通告:描述一个管道交流渠道,管道服务借助其创建关联的输入、输出管道端点。
Ø 模块类通告
Ø 模块说明通告
Ø 模块实现通告:这三类通告主要用于服务的发布与实现。一个模块类通告可以对应多种模块说明通告,一个模块说明通告也可以对应多种模块实现通告。
Ø 集合点通告:描述特定组中扮演集合点角色的对等体。
Ø 对等体信息通告:描述对等体信息资源(对等体当前状态)。
(5)消息
JXTA网络中所有的通信都是通过接收和发送消息来实现的。管道和端点传递的信息都是消息方式封装的。消息的格式分为XML格式和二进制格式两种。为了缓解使用XML格式造成的消息传送的效率低下问题,JXTA将XML格式的消息内容改为二进制格式,而其他的仍然使用XML格式。
(6)服务
所谓服务,即一个对等体或一个对等组所提供的应用。服务通过服务通告进行标识,其他对等体通过获取服务通告来定位和使用服务。
服务分为对等体服务和对等组服务。对等体服务只能由服务通告发布者进行实例化,而对等组服务可以由对等组中的任意一个想要实现特定对等组服务的对等体进行实现。
3.JXTA协议组成
对等体通过JXTA协议来实现对等体之间的通信、资源发布和发现、信息的传递和路由等功能。协议本身并不是应用程序,建立一个完整的P2P应用程序还需要添加更多的代码和相应的模块。协议隐藏了很多细节,这样使得编写JXTA应用程序比从空白开发P2P应用要容易的多。JXTA由图2.4所示六个协议组成:
图2.4 JXTA协议
其中:
端点路由协议、对等体解析协议为其他协议的支撑协议。端点路由协议用于帮助对等体发现路由(即多个对等体组成的跳序列),从而建立两对等体间的管道通信渠道。对等体解析协议允许Peer发送更一般的请求,而不单单是JXTA所提供的特定服务请求,并允许Peer接收到请求的回应。
对等体发现协议主要用来发布自己的通告信息,并且从其他Peer处获得通告。
管道绑定协议允许Peer之间建立虚拟的通信通道。该协议首要关注的是通过Peer端点路由协议提供的路由连接Peer。它使用Peer Resolver Protocol来发送和传播搜索通告的请求。
对等体信息协议用来获得其他Peer的状态信息,包括更新时间、状态等等。
集合点协议负责在JXTA对等组内传播消息,它为Peer在组内接收和发送消息并且控制消息如何传播定义了一个基本协议。通过该协议Peer在组内可以对一个服务订阅或者被订阅。
这篇关于JXTA简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!