码迷,mamicode.com
首页 > 其他好文 > 详细

开源项目 AllJoyn 框架

时间:2015-07-21 01:34:50      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:alljoyn   iot   

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 框架

标签:alljoyn   iot   

原文地址:http://blog.csdn.net/wangzhiyu1980/article/details/46963459

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!