数据分发服务(DDS, Data Distribution Service)简介

什么是DDS ?

工业物联网成熟的数据连接标准

OMG 数据分发服务 (DDS™) 是一个中间件协议和 API 标准,用于来自 Object Management Group® (OMG®) 的以数据为中心的连接。它将系统的组件集成在一起,提供业务和关键任务物联网 (IoT) 应用程序所需的低延迟数据连接、极高的可靠性和可扩展架构。

在分布式系统中,中间件是位于操作系统和应用程序之间的软件层。它使系统的各个组件能够更轻松地通信和共享数据。它让软件开发人员专注于其应用程序的特定用途,而不是在应用程序和系统之间传递信息的机制,从而简化了分布式系统的开发。

图1

DDS 中间件是一个软件层,它将应用程序从操作系统、网络传输和低级数据格式的细节中抽象出来。不同的编程语言提供相同的概念和 API,允许应用程序跨操作系统、语言和处理器架构交换信息。数据线格式、发现、连接、可靠性、协议、传输选择、QoS、安全性等低级细节由中间件管理。

数据中心(Data Centricity)

图2

DDS 提供QoS 控制的数据共享。应用程序通过发布和订阅由其主题名称标识的主题来进行通信。订阅可以指定时间和内容过滤器,并且仅获取主题上发布的数据的子集。不同的DDS域彼此完全独立。跨 DDS 域不存在数据共享。

有许多通信中间件标准和产品。DDS 具有独特的以数据为中心的特点,是工业物联网的理想选择。大多数中间件的工作原理是在应用程序和系统之间发送信息。以数据为中心可确保所有消息都包含应用程序理解其接收的数据所需的上下文信息。

以数据为中心的本质是DDS知道它存储什么数据并控制如何共享这些数据。使用传统的以消息为中心的中间件的程序员必须编写发送消息的代码。使用以数据为中心的中间件的程序员编写代码来指定如何以及何时共享数据,然后直接共享数据值。DDS 不是在应用程序(您的)代码中管理所有这些复杂性,而是直接为您实现受控、托管、安全的数据共享。

全局数据空间 (Global Data space)

从概念上讲,DDS 将本地数据存储称为“全局数据空间”。对于应用程序来说,全局数据空间看起来就像通过 API 访问的本地内存。您写入看起来像本地存储的内容。实际上,DDS 发送消息来更新远程节点上的相应存储。您从看起来像当地商店的地方阅读。

图3

在 DDS 域内,信息共享的单位是主题内的数据对象。主题由其名称来标识,数据对象由一些“Key”属性来标识。这类似于如何使用关键属性来识别数据库中的记录。这是概念图。DDS 进行点对点通信,不需要通过服务器或云来代理数据。

总而言之,本地存储给应用程序带来了可以访问整个全局数据空间的错觉。这只是一种幻觉;没有一个全球性的地方可以容纳所有数据。每个应用程序仅在本地存储其需要的内容,并且仅在需要时存储。DDS 处理动态数据;全局数据空间是一个虚拟概念,实际上只是本地存储的集合。每个应用程序,无论使用几乎任何语言,在任何系统上运行,都会以最佳的本机格式看到本地内存。全球数据空间可跨任何传输方式在嵌入式、移动和云应用程序之间共享数据,无论语言或系统如何,并且延迟极低。

服务质量(Quality of service)

数据还可以通过灵活的服务质量 (QoS) 规范进行共享,包括可靠性、系统运行状况(活跃性)甚至安全性。在真实的系统中,并非所有其他端点都需要本地商店中的所有商品。DDS 很聪明,只发送它需要的内容。如果消息并不总是到达预期目的地,中间件会在需要时实现可靠性。当系统发生变化时,中间件会动态地确定将哪些数据发送到哪里,并智能地将变化通知参与者。如果总数据量很大,DDS会智能过滤并仅发送每个端点真正需要的数据。当需要快速更新时,DDS 会发送多播消息来同时更新许多远程应用程序。随着数据格式的发展,DDS 跟踪系统各个部分使用的版本并自动翻译。对于安全关键型应用程序,DDS 控制访问、强制执行数据流路径并对运行中的数据进行加密。

当您在非常动态、要求严格且不可预测的环境中以极高的速度同时指定所有这些内容时,DDS 的真正威力就会显现出来。

动态发现(Dynamic Discovery)

DDS 提供发布者和订阅者的动态发现。动态发现使您的 DDS 应用程序可扩展。这意味着应用程序不必知道或配置通信端点,因为它们是由 DDS 自动发现的。这可以在运行时完成,而不必在设计或编译时完成,从而为 DDS 应用程序实现真正的“即插即用”。

这种动态发现比发现端点更进一步。DDS 将发现端点是否正在发布数据、订阅数据或两者。它将发现正在发布或订阅的数据的类型。它还将发现发布者提供的通信特征和订阅者请求的通信特征。在 DDS 参与者的动态发现和匹配过程中,所有这些属性都会被考虑在内。

DDS 参与者可以位于同一台计算机上,也可以跨网络:应用程序使用相同的 DDS API 进行通信。由于无需了解或配置 IP 地址,也无需考虑机器架构的差异,因此在任何操作系统或硬件平台上添加额外的通信参与者就变成了一项简单、几乎微不足道的任务。

可扩展架构(Scalable Architecture)

图4

DDS 系统可以跨越边缘、雾和云。在边缘,它们可用于高速实时机器对机器通信。在中间系统内,它们可以提供强大、可靠的 QoS 和内容感知信息流。集成这些系统 DDS 提供了可扩展的信息访问和分发方式,一直到云中以及在云中。

OMG DDS 架构设计为可从小型设备扩展到云以及超大型系统。DDS 通过扩展到数千或数百万参与者、超高速传输数据、管理数千个数据对象来实现物联网,并提供极高的可用性和安全性。DDS 通过在单个标准通信层中吸收大部分复杂性来简化分布式系统开发。

安全(Security)

保护任务关键型工业物联网环境需要从边缘扩展到云、跨系统和供应商的安全性。

DDS 包括为信息分发提供身份验证、访问控制、机密性和完整性的安全机制。DDS Security 使用分散的点对点架构,在不牺牲实时性能的情况下提供安全性。 

注意: DDS DomainParticipant 代表域中应用程序的本地成员身份。域是一个分布式概念,它将所有能够相互通信的应用程序链接起来。它代表一个通信平面:只有属于同一域的发布者和订阅者可以交互。此外,它还充当 DDS 发布者、订阅者、主题、多主题和 ContentFilteredTopics 的工厂。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/143161.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

华为杯数学建模比赛经验分享

再过一周左右,第二十届华为杯数学建模比赛就要开赛了,所以今天分享一下个人数学建模比赛的经验。 今天给大家分享一期关于华为杯数学建模比赛的经验分享,我将从以下三个方面展开说明: (1)如何准备数学建模比赛&#x…

开辟ICT新视野 直通华为云专家:一堂华为云Astro低代码启蒙课 ——华为云HCSD校园沙龙之西安站

在快速发展的信息时代,ICT(即:信息和通信技术)行业成为众多高校应届生进军的最新领域。但刚步入大学校园的学生,仍困扰于「我应该如何抓住这一趋势?怎样规划职业生涯才切实可行?」。 在飘溢激动…

vue+element plus 使用table组件,清空用户的选择项

<el-table ref"tableRef"> .... </el-table> <script lang"ts" setup> import { onMounted, reactive, ref, nextTick } from vue const clearBtn () > {console.log(清空用户的选择项)tableRef.value.clearSelection() } </scr…

八大排序详解

目录 1.排序的概念及应用 1.1 排序的概念 1.2 排序的应用 1.3 常见的排序算法 2.常见排序算法的实现 2.1 直接插入排序 2.1.1 基本思想 2.1.2 动图解析 2.1.3 排序步骤&#xff08;默认升序&#xff09; 2.1.4 代码实现 2.1.5 特性总结 2.2 希尔排序 2.2.1 基本思…

数据结构与算法基础-(3)

&#x1f308;write in front&#x1f308; &#x1f9f8;大家好&#xff0c;我是Aileen&#x1f9f8;.希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流. &#x1f194;本文由Aileen_0v0&#x1f9f8; 原创 CSDN首发&#x1f412; 如…

Java 多线程基础

文章目录 1. 认识线程1.1 概念1.1.1 线程是什么1.1.2 为什么要有线程1.1.3 进程和线程的区别1.1.4 Java的线程和操作系统线程的关系 1.2 第一个多线程程序1.3 创建线程1.4 多线程的优势 2. Thread 类及其常用的方法2.1 Thread 的常见构造方法2.2 Thread 的几个常见属性2.3 启动…

EasyExcel导出转换@ExcelProperty注解中converter不生效,以及EasyExcel导入日期转换失败问题

用EasyExcel做导出&#xff0c;需要用ExcelProperty做格式转换&#xff0c;比如日期转换&#xff0c;枚举类转换 然后新建一个转换类 里面有两个实现方法&#xff0c;converToJavaData是导入时&#xff0c;数据转换定义格式&#xff0c;converToExcelData是导出时做数据转换的。…

一款强大的ntfs磁盘读写工具Paragon NTFS 15破解版百度网盘下载

今天再给大家分享一款NTFS工具Paragon NTFS 15&#xff0c;Paragon NTFS 15破解版是目前的最新版&#xff0c;需要的赶快收藏&#xff0c;地址失效可以留言。 Paragon Ntfs For Mac 15下载&#xff1a;https://souurl.cn/s84CCB Crcak链接: https://pan.baidu.com/s/1c2Hx7QBE…

idea环境下如何打包可运行jar?

工作中有时候偶尔写一些工具类、小程序&#xff0c;可是java程序员制作一个可运行jar实在折腾&#xff0c;利用idea开发环境&#xff0c;可以快速打包自己的可运行jar。具体怎么操作呢&#xff1f; 创建一个空白的java项目并完成自己的程序开发 完成java代码&#xff1a; /**…

SpringMVC 学习(四)RestFul 风格

5. RestFul 风格 5.1 简介 概念 Restful就是一个资源定位及资源操作的风格。不是标准也不是协议&#xff0c;只是一种风格。基于这个风格设计的软件可以更简洁&#xff0c;更有层次&#xff0c;更易于实现缓存等机制。 功能 资源&#xff1a;互联网所有的事物都可以被抽象为…

华为手机如何开启设置健康使用手机模式限制孩子玩手机时间?

华为手机如何开启设置健康使用手机模式限制孩子玩手机时间&#xff1f; 1、在手机上找到「设置」并点击打开&#xff1b; 2、在设置内找到「健康使用手机」并点击进入&#xff1b; 3、开启健康使用手机后&#xff0c;选择孩子使用&#xff1b; 4、在健康使用手机内&#xff0c…

【Java接口性能优化】skywalking使用

skywalking使用 提示&#xff1a;微服务中-skywalking使用 文章目录 skywalking使用一、进入skywalking主页二、进入具体服务1.查看接口 一、进入skywalking主页 二、进入具体服务 可以点击列表或搜索后&#xff0c;点击进入具体服务 依次选择日期、小时、分钟 1.查看接口 依次…

系统集成|第十二章(笔记)

目录 第十二章 沟通管理12.1 沟通的基本概念12.2 主要过程12.2.1 规划沟通管理12.2.2 管理沟通12.2.3 控制沟通 12.3 常见问题 上篇&#xff1a;第十一章、项目人力资源管理 下篇&#xff1a;第十三章、干系人管理 第十二章 沟通管理 沟通管理在项目计划、执行、监控过程中具有…

word中使用latex多行公式,矩阵公式

\eqarray{H& [h(x_1)^T,\cdots,h(x_N)^T]^T \\ & [\matrix{g(w_1 x_1b_1) & \cdots & g(w_L x_1b_L) \\ \vdots & \ddots & \vdots \\ g(w_1 x_Nb_1) & \cdots & g(w_L x_Nb_L)}]_{N \times L}}&的引起的那条竖线可以通过backspace或者del…

在 Substance Painter中实现Unity Standard Shader

由于有需要在Substance Painter中显示什么样的效果&#xff0c;在Unity就要显示什么样的效果的需求&#xff0c;最近研究了几天&#xff0c;总算在Substance Painter中实现Unity standard的材质的渲染效果。具体效果如下&#xff1a; 在Unity中&#xff1a; Substance Painte…

sdk下载慢的解决办法

Android studio版本&#xff1a;为Android Studio 4.1.1&#xff0c; 先完成Android Studio软件安装&#xff0c;打开Android Studio&#xff0c;点击File -> settings->Android SDK&#xff0c;按照开发需要安装sdk platform、SDK Tools工具。 sdk下载慢解决办法 1、…

面试必杀技:Jmeter性能测试攻略大全(第一弹)

前言 性能测试是一个全栈工程师/架构师必会的技能之一&#xff0c;只有学会性能测试&#xff0c;才能根据得到的测试报告进行分析&#xff0c;找到系统性能的瓶颈所在&#xff0c;而这也是优化架构设计中重要的依据。 第一章 测试流程&#xff1a; 需求分析→环境搭建→测试…

《玩转smardaten | GIS地图无码化配置全方位指南》

GIS地图作为一种特殊图表&#xff0c;将地理位置信息和地图结合起来进行处理、管理和分析。 这些地图可以让用户以多种方式查看、分析和解释地理数据&#xff0c;包括创建图层、生成主题地图和执行空间分析等&#xff0c;更加形象完整的辅助数据可视化。常用的场景如&#x1f…

MATLAB中norm函数用法

目录 语法 说明 示例 向量模 向量的 1-范数 两个点之间的欧几里德距离 矩阵的 2-范数 N 维数组的 Frobenius 范数 常规向量范数 norm函数的功能是计算向量范数和矩阵范数。 语法 n norm(v) n norm(v,p) n norm(X) n norm(X,p) n norm(X,"fro") 说明…

Python二级 每周练习题20

练习一: 日期计算器 设计一款日期计算程序&#xff0c;能否实现下面的功能&#xff1a; (1)要求用户分别输入年、月、日&#xff08;分三次输入&#xff09;&#xff1b; (2)程序自动会根据输入的年月日计算出这一天是这一年的第几天&#xff1b; (3)输出格式为&#xff1a;这…