ONOS架构-系统组件
系统组件
系统分层
App/core/providers

业务和子系统
一个业务service是有多个组件构成的功能单元,基于各层软件栈提供一个垂直的分片slice,将构成业务service的组件集合称为子系统。业务和子系统可互换使用。
onos定义的业务有:
.设备子系统-管理设备-交换机-资产
.链路子系统-管理链路资产
.主机子系统-管理主机及在网络中的位置
.拓扑子系统-管理网络视图
.路径path---基于最新的拓扑,在交换机之间,或者主机之间计算和发现路径
.流规则子系统-管理应用到交换机上的流规则(匹配和动作match/action),提供流数据(flow metrics)
.报文收发子系统-允许app监听来自交换机的数据报文,以及通过一个多个交换机向网络发送数据报文

每一个子系统的组件都在某个层级中(app/core/providers),可用实现了的一个或者多个java接口标识。
下图描述了子系统组件的关系,上下两个虚线是由南北向接口定义的层级边界。

Provider
三层中最低一层,向网络通过协议特定的协议栈提供接口,向内核通过ProviderService提供接口。
协议感知的provider通过各种网络控制和配置协议和网络交互,向内核提供业务相关的数据,provider也从其他模块收集数据,转换为(本)业务相关数据。
某些provider从内核接收控制指令,并通过协议特定的方式应用到网络,这些通过provider接口传递给provider。
Provider ID
Provider会关联一个ProviderID,用于在同一类Provier中提供外部标识,并允许在provider卸载后交换机或者其他模型实体依然能保留和provider的关联。
ProviderID携带URI,可允许交换机和Provider进行配对,而无需访问provider对象本身。
Multiple Provider
子系统可个关联多个provider,provider有primary和ancillary两种角色,primary拥有关联到业务的所有实体,ancillary类型的privider则以overlay方式提供信息。此种方式,为主要provider提供了某种优先权,处理underlay的冲突信息
Manager
内核模块,从provider接收信息,提供给应用或者其他业务service。
有如下interface
.北向接口,应用和其他内核模块可获取特定网络状态
.AdminService接口,接受管理命令,应用到网络或者系统中
.南向ProviderRegistry接口,Provider通过接口向Manager注册
.南向ProviderService接口,已注册的Provider向Manager接收/发送信息
Manager 业务接口的consumer可通过同步方式(查询业务)和异步方式(事件监听,实现EventListener接口)
Store
在内核,和Manager中,store用于保存,索引,同步manager收到的信息,通过和其他onos实例中的store直接通信,保证跨多个ONOS实例的一致性和健壮性,
Application
应用经由AdminService接口和业务接口操作Manager聚合的数据,应用的范围很广
ApplicationID
每个应用都分配一个唯一的APPID,用于 ONOS跟踪应用的上下文(诸如intent,flow rules这样的任务对象),应用使用CoreService接口注册,提供反转的DNS,名字,从而获取AppID。
注,并非所有子系统都如上操作,也并非所有组件都严格按照如上实现功能,比如TopologyProvider相对系统内核以协议无关方式呈现设备和链路,从不和设备直接交互,由CoreManager实现的CoreService,仅仅是业务接口。
Events and Descriptions
ONOS内核中关于事件分发的两个基本单元是event和description,两者可以经由业务接口,和特定网络元素和概念关联,一旦创建,两者都是不变的(immutable)
Description用于通过南向接口传递信息,比如HostDescription包含主机的mac,ip地址,在网络中的位置(VLANID,交换机和端口),Description通常有model/objects,以及各种网络组件的onos表达,组成。
Event,
Manager使用event来通知监听者网络状态的改变,Store用来通知分布式对端。Event由类型type和表示模型对象的主题subject组成,比如DeviceEvent可用来通知DeviceListener某个设备device(subject)被检测(DEVICE_ADDED),删除(DEVICE_REMOVED),属性变化(DEVICE_UPDATED)
Event分发
由store产生的event,输入来自Manager。一旦产生,将通过StoreDelegate接口分发给感兴趣的监听者,StoreDelegate最终会调用EventDeliveryService接口,StoreDelegate将event从store中移出,EventDeliveryService保证event会到达监听者,由manager实现StoreDelegate的实现类
Event监听
任何实现了EventListen接口的组件都是事件监听器,事件监听器由其所监听的event的子类的类型确定,事件监听器的典型实现是作为Manager或者应用的inner类,根据收到的event调用合适的业务。这个限制了从外部处理子系统到子系统的Manager,或者子系统到应用的event。、
下图描述了description和event以及相关的组件。

ONOS架构-系统组件的更多相关文章
- iOS应用架构谈 组件化方案
转载: iOS应用架构谈 组件化方案 简述 前几天的一个晚上在infoQ的微信群里,来自蘑菇街的Limboy做了一个分享,讲了蘑菇街的组件化之路.我不认为这条组件化之路蘑菇街走对了.分享后我私聊了Li ...
- 基于SOA的高并发和高可用分布式系统架构和组件详解
基于SOA的分布式高可用架构和微服务架构,是时下如日中天的互联网企业级系统开发架构选择方案.在核心思想上,两者都主张对系统的横向细分和扩展,按不同的业务功能模块来对系统进行分割并且使用一定的手段实现服 ...
- zuul 路由网关 微服务架构系统中
在微服务架构中,基本包含以下常见的组件.服务注册与发现.服务消费.负载均衡.断路器.只能路由.配置管理等.一个简单的微服务架构系统如下 一.Zuul简介 Zuul的主要功能是路由转发和过滤器.路由功能 ...
- k8s架构与组件详解
没有那么多花里胡哨,直接进行一个K8s架构与组件的学习. 一.K8s架构 k8s系统在设计是遵循c-s架构的,也就是我们图中apiserver与其余组件的交互.在生产中通常会有多个Master以实现K ...
- 详解工作流框架Activiti的服务架构和组件
摘要:通过这篇文章,可以对工作流有一个基本的认识,为后续工作流框架Activiti的学习打下坚实的基础. 本文分享自华为云社区<BPMN工作流的基本概念!详解工作流框架Activiti的服务架构 ...
- Shiro学习之路 -- 架构及其组件
出自:跟我学shiro 简介 Apache Shiro 是 Java 的一个安全框架.目前,使用 Apache Shiro 的人越来越多,因为它相当简单,对比 Spring Security,可能没有 ...
- xp 专业版组策略只有系统组件
想要不显示任务栏的提示消息,需要在组策略里面设置,(在"开始→运行"中输入"GPEDIT.MSC"打开组策略,然后依次选择"用户配置→管理模板→任务栏 ...
- Kunernetes集群架构与组件
架构如图: master节点:主要是集群控制面板的功能,来管理整个集群,包括全局的角色,调度,都是在master节点进行控制 有三个组件: API Server: 是 k8s提供的一个统一入口,它是 ...
- 02Oracle Database 安装,卸载,系统服务,系统组件及系统表空间
Oracle Database 安装,卸载,系统服务,系统组件及系统表空间 Oracle Database 安装 Oracle Database 卸载 Oracle Database 系统服务 Ora ...
随机推荐
- ZOJ 4062 - Plants vs. Zombies - [二分+贪心][2018 ACM-ICPC Asia Qingdao Regional Problem E]
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4062 题意: 现在在一条 $x$ 轴上玩植物大战僵尸,有 $n$ ...
- Gym 101873I - Uberwatch - [DP]
题目链接:http://codeforces.com/gym/101873/problem/I 题意: 给出 $n(1 \le n \le 300000)$ 个单位时间,每个单位时间给出一个 $x_i ...
- 第二周作业-web后台应用开发与xml
web后台: 网站前台和网站后台通常是相对于动态网站而言,即网站建设是基于数据库开发 的网站.基于带数据库开发的网站,一般分网站前台和网站后台.网站前台是面向网站访问用户的,通俗的说也就是给访问网站的 ...
- 《Mysql 数据类型》
一:整型 - 常用类型 类型 占用(字节) 范围 无符号范围 无符号范围 TINYINT 2的8次方 - — — SMALLINT 2的15次方 - — 6553 5 INT 2的31次方 - — 4 ...
- JAVA-数据库之MySQL与JDBC驱动下载与安装
相关资料:<21天学通Java Web开发> MySQL下载地址:https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.19-wi ...
- Linux服务器可以进百度,但是进阿里云或者别的一些网站提示‘错误代码:NS_ERROR_NET_INADEQUATE_SECURITY’的问题
昨天遇到一个头疼的事情,在阿里云买了一台服务器: 然后环境各种都装了,因为本人是小白,所以一般都装MATE界面: 一开始环境没配好,访问百度可以进去,进万网但是进不去,先也没急着搞这个事情,第一天晚上 ...
- kubectl批量删除pvc
#!/bin/bashkubectl get pvc |grep hub > tmp.txtcat tmp.txt |awk '{split($0,a," ");print ...
- 【UML】-NO.45.EBook.5.UML.1.005-【UML 大战需求分析】- 通讯图(Communication Diagram)
1.0.0 Summary Tittle:[UML]-NO.45.EBook.1.UML.1.005-[UML 大战需求分析]- 通讯图(Conmunication Diagram) Style:De ...
- Objective-C RunTime 学习笔记 之 AutoReleasPool
1.结构 struct magic_t { /* 魔法 */ static const uint32_t M0 = 0xA1A1A1A1; # define M1 "AU ...
- 如何导出不带.svn的文件夹项目
实际工作中有需要导出项目,却含有大量的.svn文件夹,有以下几种方式导出: 一.TortoiseSVN导出 项目文件夹,右键->TortoiseSVN->导出(Export),勾选“导出无 ...