Alljoyn之管中窥豹

简介: Alljoyn之管中窥豹   一、历史: Alljoyn是高通2011年推出的近距离P2P通讯技术,它为分布式应用程序在不同设备中提供了运行环境,特别是移动性、安全性和动态配置,支持Microsoft Windows、Linux、ios和Android等主流的操作系统平台,可以说AllJo...

Alljoyn之管中窥豹

 

一、历史:

Alljoyn是高通2011年推出的近距离P2P通讯技术,它为分布式应用程序在不同设备中提供了运行环境,特别是移动性、安全性和动态配置,支持Microsoft WindowsLinuxiosAndroid等主流的操作系统平台,可以说AllJoyn是专门处理异构分布式系统中的难题而产生的,同时Alljoyn还是一项开源项目(项目地址http://www.alljoyn.org),按道理说应该很火才对,

(怎么就没火起来呢???)

因此高通在201312月份将该项目贡献了处理,并拉了一帮的大佬小弟(Linux 基金会、HTC、思科、LG、夏普、海尔、松下、Silicon Image、TP-Link等)成立了AllSeen联盟,旨在建立、维护统一的设备间通讯标准也就是物联网互联架构可以让家中的电视、机上盒、路由器、智能照明系统和其他设备无缝地连接起来,并跨越iOS、Android、Windows 或 Mac 等不同的作业系统。

(我们一起来玩吧)

现在这个项目是由Linux 基金会来管理和运作,并添加一些功能模块(之前只有通讯框架)如音频推送,设备控制等,所以个人觉得比较靠谱,正好项目需要用到这方面的技术,也就来潜心研究学习下。——allseen的项目地址是 http://www.allseen.org

二、优点:

1、开源

这个是我们最喜爱它的原因,没有之一。

2、操作系统的独立性

AllJoyn提供了一个抽象层,允许AllJoyn及其应用程序运行在多个操作系统平台上。支持的系统包括Windows XP , Windows 7, Windows RT , and Windows 8Android 2.2和更高版本,Linux发行版本如Ubuntu以及苹果操作系统iOS OS X

3、开发语言的独立性

目前,支持的语言有C++,Java, C#, JavaScript,Objective-C.

4、物理网络和协议的独立性

现在,网络设备支持许多的通信技术。AllJoyn提供了一个抽象层,它为底层网络协议栈定义了统一的接口,使得软件工程师可以相对容易地添加和安装新的网络。

Wi-Fi联盟已经发布了一个Wi-Fi Direct规范,这将允许点对点的Wi-Fi连接。并且Wi-Fi Direct的网络硬件模块也正在积极开发中,它将为AllJoyn开发者增加Wi-Fi Direct功能和可用网络选项的预关联发现机制。

5、最重要的就是上面这几点,当然还有其他很多。。。。。。

三、概念

1AllJoyn总线

AllJoyn系统最基本的抽象就是AllJoyn总线。它为分布式系统提供了一个快速、轻量级的方式来传递消息序列。你可以将AllJoyn总线看作是消息传递的"高速公路"。图2显示了单一设备上AllJoyn总线实例在理论上的结构。总线用加粗的水平黑线表示。垂直线可以被认为是消息通过总线在源点和目的点之间传递的"出口"

2所示的总线连接被描述为了六边形(这是任意选择的形状)。正如高速公路的出口通常都具有编号,图中每个连接都分配了唯一的连接名称。为了清晰起见,这里使用连接名称的简化形式。

许多情况下,总线上的连接都可以被认为是进程的合作方。因此,在图2的例子中,独特的连接名称:1.1可能被分配给应用程序实例进程的一个连接,而独特的连接名称:1.4可能被分配给其它应用程序实例进程的连接。AllJoyn总线的目标就是让两个应用程序进行通信,而无需处理底层机制的细节。其中一个连接可以认为是客户端存根,另一方就可以认为是服务器存根。

2. 典型的AllJoyn总线

2显示了AllJoyn总线的一个实例,说明了软件总线如何给连接到总线上的组件提供进程间通信。AllJoyn总线的典型设备扩展如图3所示。组件可根据需要,在SmartphoneLinux主机上的组件之间创建逻辑总线段之间的通信链路。

3. AllJoyn处理设备到设备的通信

通信链路的管理由AllJoyn系统负责,并且由许多底层技术组成,例如Wi-Fi和蓝牙技术。可能有不同的设备参与管理AllJoyn总线,但是这对分布式总线上的用户都是透明的。对于总线上的某个组成部分,分布式AllJoyn系统看起来就像是本地设备中的总线。

4显示了分布式总线对于总线上的用户是如何呈现的。一个组件(例如,智能手机连接的名称为1.1)可以创建一个进程来调用Linux主机上的名称为1.7的组件,而无需担心该组件的物理位置。

4. 分布式AllJoyn总线类似一条本地总线

2、总线守护进程

3说明了逻辑分布式总线实际上被分成了若干个段,每个段都运行在不同的设备上。AllJoyn从功能上实现这些逻辑总线段的进程被称为AllJoyn守护进程。

Unix派生系统中的长驻守护进程,通常用来描述运行在计算机系统中并提供一些必要功能的程序。在Windows系统中,长驻服务更加常见,但是我仍然是指AllJoynWindows系统中的守护进程。

5. 总线的相关气泡图形

为了让AllJoyn守护进程更形象化,我们创建气泡图是很有用的。考虑两段AllJoyn总线,一段位于Smartphone上而另一段位于Linux主机,如图5所示。总线连接被标记为了客户端(C)和服务器(S)基于RMI模型。执行分布式总线核心的守护进程被标记为(D)。图5中的组件通常被解释为如图6所示的插图。

6. AllJoyn气泡图形

气泡可以被看作分布式系统上运行的计算机进程。左侧的两个客户端(C)和一个服务(S)进程运行在Smartphone上。这三个进程与Smartphone上的AllJoyn守护进程通信,实现了分布式AllJoyn总线上的本地网段。在右侧,也有一个守护进程,它在Linux主机上实现了AllJoyn总线的本地网段。这两个守护进程将协调整个逻辑总线的消息流,如图4所示,逻辑总线是单一的实体连接。类似Smartphone中的配置,Linux主机上有两个服务组件和一个客户端组件。

在此配置中,客户端组件C1可以采用远程方法来调用服务组件S1,就像它是一个本地对象。参数在源头进行封装,并由Smartphone上的守护进程送至本地总线段的路由。封装参数通过网络链接(从客户端来看是透明的)发送至Linux主机上的守护进程。而Linux主机上运行的守护进程确定目的地是S1,并且对封装参数进行拆封,然后通知服务去调用远程方法。如果有返回值,那么将反向进行这个通信过程,把返回值传回给客户端。

由于守护进程在后台运行,并且客户端和服务都运行在单独的进程中,所以在每个单独进程中必须有一个守护进程的"代理" AllJoyn将调用这些代理总线附件。

3、总线附件

每个AllJoyn总线连接都需要一个特定的AllJoyn组件作为介质,它称为总线附件。每个需要连接AllJoyn总线的进程都有一个总线附件。

当在硬件和软件之间讨论软件组件时,往往会引出一个比喻。我们可以将分布式AllJoyn总线的本地网段想象为台式电脑的底板硬件总线。硬件总线本身就能传递电子信息,并且有一个可以插卡的点称为连接器。AllJoyn中类似功能的连接器就是总线附件。

AllJoyn总线附件是本地指定语言的对象,它代表了分布式AllJoyn总线中的客户端、服务或对等点。例如,这里有为用户提供总线附件功能的C++语言实现,还有为用户提供相同总线附件功能的Java语言实现。由于AllJoyn增加了语言支持,将会有更多这样的具体语言实现。

4、总线方法、总线属性和总线信号

AllJoyn基本上是一个面向对象的系统。在面向对象的系统中,人们将谈论对象中的调用方法(因此对于分布式系统,人们将谈论长驻远程方法调用)。面向对象编程中的对象需要有成员。通常,还需要对象方法或属性,在AllJoyn中就是BusMethodsBusPropertiesAllJoyn同样也有总线信号(BusSignal),它是对象中某些事件或状态变化的异步通知。

为了使客户端、服务和对等点之间的通信更加透明,那么总线方法和总线信号中的参数顺序必须有一些规范,并且总线属性中也必须有一些形式的类型信息。对于计算机科学,方法(或信号)输入和输出类型的申明或定义被称为类型签名。

类型签名使用字符串来定义,包括所有的基本数字类型(对于大多数编程语言),以及从这些基本类型创建出的复合类型,例如数组和结构体。类型签名的具体分配和使用超出了本文介绍的范围,但是总线方法、信号或属性的类型签名将传递给AllJoyn底层系统,来实现总线上传递参数和封装返回值的转换。

5、总线接口

在大多数面向对象的编程系统中,方法或属性集合将合并到具备固有内在联系的群组中。该集合函数的统一申明被称为接口。接口为执行接口规范的实体与外界之间的连接提供服务。正因为如此,接口需要适当的标准结构来实现标准化。各种网站上可以找到众多的接口服务规范,从电话到媒体播放器控制。D-Bus规范在XML中进行描述来指定接口。

接口规范会将总线方法、总线信号、总线属性以及与它们相关的类型签名组合到一个命名组中。而实际上,接口会由客户端、服务或对等点进程来实现。如果实现了给定的命名接口,那么在这个实现和外界之间会有一个隐性契约,接口将会支持它所有的总线方法、总线信号和总线属性。

接口名称通常采用域名反转形式。例如,这里有许多AllJoyn实现的标准接口。其中有一个标准接口是theorg.alljoyn.Businterface,将守护实现并为总线附件提供一些基本功能。

值得注意的是,接口名称仅仅是相对自由形式的命名空间中的一个字符串,并且其它命名空间可能也有类似的外观。接口名称字符串提供的特定函数不应该和其它类似的字符串混淆,特别是总线名称。例如,org.alljoyn.sample.chat可能是总线名称常量,就是客户端搜索的名字。但是也有可能org.alljoyn.sample.chat是接口名称,它定义了总线对象采用特定的总线名称连接到总线附件上时提供的方法、信号和属性。如果存在给定接口名称的接口就暗示了总线名称的存在;但是,它们确实是两个完全不同的东西,有时可能长得一模一样。

6、总线对象和对象路径

总线接口提供了一种标准的方式来声明分布式系统中的接口。总线对象提供桥接到可能实现给定接口规范的地方。总线对象存在于总线附件中,并作为通信的终点。

因为,在特殊的总线附件中特定的接口可能会有多种实现,所以必须增加额外的结构体来区分这些接口实现。这将由对象路径来提供。

就像接口名称是命名空间中的一个字符串,对象路径同样也存在于命名空间中。命名空间的结构就像一棵树,路径的思维模式就是文件系统的目录树。事实上,对象路径的路径分隔符使用的是斜杠字符,和Unix文件系统类似。由于总线对象是总线接口的实现,所以对象路径可以遵循相应接口的命名约定。如果定义了一个磁盘控制器接口(exampleorg.freedesktop.DeviceKit.Disks),那么你就可以想象,对于同一系统中的两个分开的物理磁盘,这个接口的不同实现应该遵循下面的对象路径:

/org/freedesktop/DeviceKit/Disks/sda1

/org/freedesktop/DeviceKit/Disks/sda2

 

概念多了一下子也记不住,我的理解是:AllJoyn总线是对底层通信的抽象,我们在实际的应用中并不需要关注它;总线附件是与总线连接的接口,每一个ALLJoyn应用都需要创建一个总线附件来与总线通信;总线接口与面向对象编程中的接口类似,是应用服务的抽象,它包含有总线方法、总线属性和总线信号;总线对象才是总线方法,总线信号处理函数的实现体,总线接口与总线对象都需要与总线附件绑定才能生效。下一篇分析代码,来帮助我们更好地理解!

目录
相关文章
|
2月前
|
网络协议 数据安全/隐私保护 网络虚拟化
计算机网络的体系结构
OSI模型,即开放系统互连模型,由ISO于1984年提出,是计算机网络通信的参考模型,将网络功能划分为七层:物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。各层负责不同的通信任务,使网络设计与管理更加模块化和高效。
116 1
|
7月前
|
网络协议 数据安全/隐私保护 网络架构
就该这样理解 OSI 七层参考模型、浅谈不同局域网之间的通信
就该这样理解 OSI 七层参考模型、浅谈不同局域网之间的通信
|
8月前
|
存储 网络架构
【计算机网络】扩展以太网方法总结
【计算机网络】扩展以太网方法总结
106 1
|
8月前
|
存储 网络协议 网络性能优化
计算机网络:快速了解网络框架
计算机网络:快速了解网络框架
108 0
|
算法 数据安全/隐私保护
【计算机网络】MAC层(三)经典以太网的MAC子层协议
前言 本文将会围绕下图来展开描述: 背景 上图为经典以太网的MAC子层协议的前后两个版本。 为什么要有这样一个协议? ————因为直接通过线路发送二进制编码,站点无法将0与空闲线路区分开。
686 0
|
数据安全/隐私保护 流计算 Windows
【计算机网络】媒介访问控制子层(MAC)(一)概念理解
网络连接分为两类,一类是端到端连接(在物理层一章详细介绍了,我后面再整理),一类是通过广播信道,其中的一个关键问题是当存在竞争时,谁能获得信道的使用权。 本文中提到的一些协议用于解决该问题。
560 0
|
网络协议 网络架构
网络体系结构及通信协议
网络体系结构的基本概念。
327 0
网络体系结构及通信协议
|
网络协议 安全 5G
计算机的网络参考模型与5G协议
1 分层思想 2 OSI参考模型 3 TCP/IP 协议族的组成 4 数据的封装与解封 5 层间通讯过程 6 空口协议
计算机的网络参考模型与5G协议
|
缓存 网络协议 应用服务中间件
【图解计算机网络】物理层和MAC层的亲密关系
机器有了IP,就能在网络和其他机器通信。
315 0
【图解计算机网络】物理层和MAC层的亲密关系
西门子PPI协议的工控通信控件
PPI协议是西门子PLC的私有协议,但是PPI又是西门子PLC200系列的默认的协议,如果用公开协议Modbus还得占用目前的程序空间和变量空间。这个控件开发已久,在工控现场已经稳定可靠的运行了几年,性能和可靠性都不错。可操作的变量类型有I、Q、M、V、S、SM。 提供有详细的示例程序,很容易掌握
667 0