JXTA简介

2023-12-02 13:18
文章标签 简介 jxta

本文主要是介绍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简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445488

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

【Tools】AutoML简介

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 AutoML(自动机器学习)是一种使用机器学习技术来自动化机器学习任务的方法。在大模型中的AutoML是指在大型数据集上使用自动化机器学习技术进行模型训练和优化。

SaaS、PaaS、IaaS简介

云计算、云服务、云平台……现在“云”已成了一个家喻户晓的概念,但PaaS, IaaS 和SaaS的区别估计还没有那么多的人分得清,下面就分别向大家普及一下它们的基本概念: SaaS 软件即服务 SaaS是Software-as-a-Service的简称,意思是软件即服务。随着互联网技术的发展和应用软件的成熟, 在21世纪开始兴起的一种完全创新的软件应用模式。 它是一种通过Internet提供

LIBSVM简介

LIBSVM简介 支持向量机所涉及到的数学知识对一般的化学研究者来说是比较难的,自己编程实现该算法难度就更大了。但是现在的网络资源非常发达,而且国际上的科学研究者把他们的研究成果已经放在网络上,免费提供给用于研究目的,这样方便大多数的研究者,不必要花费大量的时间理解SVM算法的深奥数学原理和计算机程序设计。目前有关SVM计算的相关软件有很多,如LIBSVM、mySVM、SVMLight等,这些

urllib与requests爬虫简介

urllib与requests爬虫简介 – 潘登同学的爬虫笔记 文章目录 urllib与requests爬虫简介 -- 潘登同学的爬虫笔记第一个爬虫程序 urllib的基本使用Request对象的使用urllib发送get请求实战-喜马拉雅网站 urllib发送post请求 动态页面获取数据请求 SSL证书验证伪装自己的爬虫-请求头 urllib的底层原理伪装自己的爬虫-设置代理爬虫coo

新一代车载(E/E)架构下的中央计算载体---HPC软件架构简介

老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节能减排。 无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事.而不是让内心的烦躁、焦虑、毁掉你本就不多的热情和定力。 时间不知不觉中,快要来到夏末秋初。一年又过去了一大半,成