您的位置:首页 > 其它

开源项目 AllJoyn 框架

2015-07-21 22:50 260 查看

AllJoyn框架概述

AllJoyn实现的是一个”分布式软件总线”

总线为点对点模式

协议不依赖于网络

这三点是从介绍的PPT中翻过来的,但理解简单理解一下看以认为,这个框架是分布式的一个中间层通信框架,主要是支持点对点通信,并且由中间层屏蔽了底层物理网络的差异,对上层高级编程语言直接提供接口。

高层系统框架



此图摘自(AllJoyn - Tech Overview v3_for Brooks)

从高层的这个框架中可以看出系统中只有两种节点:

Routing Nodes (RN)

Leaf Nodes(LN)

其规则是RN可以与RN和LN通信,LN只能和RN通信。

这里两张图片展示了Router间通信的一个过程,发现和建立Session。这是High-Level System Architecture中通信的一个简单的实例。

Ad Hoc Bus Formation: Discovery



这里Client App和设备内部Router建立了内部链接,Client端的Router会通过查找interface找到Service的Router。

Ad Hoc Bus Formation: Session Creation



Router间建立了Session使得Client能获得Service的服务。

Software Components

这部分相算是开始进入了正题。

软件组件的高层的框架:分为了基础服务框架(Base Service Frameworks 和 核心框架 Core Framework )



软件组件也可以划分为 Client Library 和 Router

Client Library:

开发用户的接口

以SDK API的形式对外发布

分为两种Stand Client 和 Thin Client

SC针对High Level 的操作系统,Thin Client针对嵌入式系统或小内存系统使用。

Router:

任何App包含了Router,它便可以认为是一个Router Node

Router 必须使用 Stand Client Library 构建,必须运行在HLOS中。

它可以被部署为单独的服务或守护进程

Router功能包含了Bus管理和AllJoyn消息路由

关于AllJoyn 的SDK

AllJoyn 程序是通过 API的形式对外提供功能的,它是一个对象实现的。

大部分的程序都只是对外保留一个对象。对象会对外提供很多接口,这些API可以通过About来查询。

接口由三种形式组成:

Method(方法):与对象进行交互

Signals(信号):异步事件的通知

Property(属性): 读取或设置数据

下面的图示是关于API接口的使用过程。

首先是连接到Bus

Applications 要Attach到Bus上

左侧对象会被发布到Bus 本地的Attachment上。

在对端会定义一个代理对象(Proxy Object)

信号处理的Handler会被注册到右端的Bus Attachment上来处理Object 发出的信号。



Method(方法)的使用是通过使用Proxy Object来实现的。

调用右侧Proxy的接口时,会触发左侧Method Handler注册的处理函数,执行后并返回值到Proxy Object中。

Signal(信号)是由左侧Object触发,通过右侧注册的Signal Handler进行处理。



有了这两张图,一个基本的操作流程就被串起来了。这个还是有点像CORBA的思路。

AllJoyn Security 框架

Security Framework的几个特点

鉴权和加密被设计为 App 到 App的。设备间并不存在关系。

每一个接口的安全性。

App中可以有加密的接口和开放的接口,如果有需要的话在初始化时app 间会交换key。

安全的启用接口。

调用方法时需要认证,接受Signal时需要认证,消息都是加密的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: