Jump to content
 







Main menu
   


Navigation  



Main page
Contents
Current events
Random article
About Wikipedia
Contact us
Donate
 




Contribute  



Help
Learn to edit
Community portal
Recent changes
Upload file
 








Search  

































Create account

Log in
 









Create account
 Log in
 




Pages for logged out editors learn more  



Contributions
Talk
 



















Contents

   



(Top)
 


1 Architecture  



1.1  Model  





1.2  Interoperability  







2 History  





3 See also  





4 References  














Data Distribution Service






Català
Deutsch
Español
فارسی
Français

Italiano

Português
Русский
Українська
 

Edit links
 









Article
Talk
 

















Read
Edit
View history
 








Tools
   


Actions  



Read
Edit
View history
 




General  



What links here
Related changes
Upload file
Special pages
Permanent link
Page information
Cite this page
Get shortened URL
Download QR code
Wikidata item
 




Print/export  



Download as PDF
Printable version
 




In other projects  



Wikimedia Commons
 
















Appearance
   

 






From Wikipedia, the free encyclopedia
 


The Data Distribution Service (DDS) for real-time systems is an Object Management Group (OMG) machine-to-machine (sometimes called middleware or connectivity framework) standard that aims to enable dependable, high-performance, interoperable, real-time, scalable data exchanges using a publish–subscribe pattern.

DDS addresses the real-time data exchange needs of applications within aerospace, defense, air-traffic control, autonomous vehicles, medical devices, robotics, power generation, simulation and testing, smart grid management, transportation systems, and other applications.

Architecture[edit]

Model[edit]

DDS is a networking middleware that simplifies complex network programming. It implements a publish–subscribe pattern for sending and receiving data, events, and commands among the nodes. Nodes that produce information (publishers) create "topics" (e.g., temperature, location, pressure) and publish "samples". DDS delivers the samples to subscribers that declare an interest in that topic.

DDS handles transfer chores: message addressing, data marshalling and de-marshalling (so subscribers can be on different platforms from the publisher), delivery, flow control, retries, etc. Any node can be a publisher, subscriber, or both simultaneously.

The DDS publish-subscribe model virtually eliminates complex network programming for distributed applications. [citation needed]

DDS supports mechanisms that go beyond the basic publish-subscribe model. [citation needed] The key benefit is that applications that use DDS for their communications are decoupled. Little design time needs be spent on handling their mutual interactions. In particular, the applications never need information about the other participating applications, including their existence or locations. DDS transparently handles message delivery without requiring intervention from the user applications, including:

DDS allows the user to specify quality of service (QoS) parameters to configure discovery and behavior mechanisms up-front. By exchanging messages anonymously, DDS simplifies distributed applications and encourages modular, well-structured programs. [citation needed] DDS also automatically handles hot-swapping redundant publishers if the primary fails. [citation needed] Subscribers always get the sample with the highest priority whose data is still valid (that is, whose publisher-specified validity period has not expired)[citation needed]. It automatically switches back to the primary when it recovers, too[citation needed].

Interoperability[edit]

Both proprietary and open-source software implementations of DDS are available. These include application programming interfaces (APIs) and libraries of implementations in Ada, C, C++, C#, Java, Python, Scala, Lua, Pharo, Ruby, and Rust.

DDS vendors participated in interoperability demonstrations at the OMG Spring technical meetings from 2009 to 2013.[1][2][3][4][5][6]

During demos, each vendor published and subscribed to each other's topics using a test suite called the shapes demo. For example, one vendor publishes information about a shape and the other vendors can subscribe to the topic and display the results on their own shapes display. Each vendor takes turns publishing the information and the other subscribe. Two things made the demos possible: the DDS-I or Real-Time Publish-Subscribe (RTPS) protocol,[7] and the agreement to use a common model.

OMG Data Distribution Service interoperability

In March 2009, three vendors demonstrated interoperability between the individual, independent products that implemented the OMG Real-time Publish-Subscribe protocol version 2.1 from January 2009. The demonstration included the discovery of each other's publishers and subscribers on different OS Platforms (Microsoft Windows and Linux) and supported multicast and unicast network communications.[1]

The DDS interoperability demonstration used scenarios such as:

History[edit]

Development of the DDS specification started in 2001. In 2004, the Object Management Group (OMG) published DDS version 1.0.[8] Version 1.1 was published in December 2005,[9] 1.2 in January 2007,[10] and 1.4 in April 2015.[11] DDS is covered by several US patents,[12][13][14][15] among others.

The DDS specification describes two levels of interfaces:

Other related standards followed the initial core document. The Real-time Publish-Subscribe Wire Protocol DDS Interoperability Wire Protocol Specification ensured that information published on a topic using one vendor's DDS implementation is consumable by one or more subscribers using the same or different vendor's DDS implementations. Although the specification is targeted at the DDS community, its use is not limited. Versions 2.0 was published in April 2008, version 2.1 in November 2010, 2.2 in September 2014, and 2.3 in May 2019.[7]

DDS for Lightweight CCM (dds4ccm) offers an architectural pattern that separates the business logic from the non-functional properties. A 2012 extension added support for streams.[16] A Java 5 Language PSM for DDS defined a Java 5 language binding, referred to as a Platform Specific Model (PSM) for DDS. It specified only the Data-Centric Publish-Subscribe (DCPS) portion of the DDS specification; Additionally, it encompasses the DDS APIs introduced by DDS-XTypes and DDS-CCM. DDS-PSM-Cxx defines the ISO/IEC C++[17] PSM language binding, referred to as a Platform Specific Model (PSM) for DDS. It provides a new C++ API for programming DDS that is more natural to a C++ programmer.[18] The specification provides mappings for the application programming interface (API) specified in DDS-XTypes, and accessing quality of service (QoS) profiles specified in DDS-CCM.

Extensible and Dynamic Topic Types for DDS (DDS-XTypes) provided support for data-centric publish-subscribe communication where topics are defined with specific data structures. To be extensible, DDS topics use data types defined before compile time and used throughout the DDS global data space. This model is desirable when static type checking is useful.[19]AUnified Modeling Language (UML) profile specified DDS domains and topics to be part of analysis and design modeling.[20] This specification also defined how to publish and subscribe objects without first describing the types in another language, such as XML or OMG IDL.[21]Aninterface definition language (IDL) was specified in 2014 independently from the Common Object Request Broker Architecture (CORBA) specification chapter 3. This IDL 3.5 was compatible with the CORBA 3 specification, but extracted as its own specification allowing it to evolve independently from CORBA.[22]

Other protocols to be mentioned are: DDS-XRCE (DDS for eXtremely Resource Constrained Environments), this specification protocol allows the communication between devices of limited resources, like microcontroller for example and a DDS network. It makes publishing and subscribing to topics via an intermediate service in a DDS domain possible [23] and DDS-RPC (RPC Over DDS) which defines Remote Procedure Calls. These provide a bidirectional request/reply communication and determine distributed services, and are detailed using a service interface. It also supports both synchronous and asynchronous method invocation. [24]

Starting with DDS version 1.4 in 2015, the optional DLRL layer was moved to a separate specification.[25]

See also[edit]

References[edit]

  1. ^ a b Angelo Corsaro, Gerardo Pardo-Castellote and Clark Tucker (August 12, 2009). "DDS Interoperability Demo" (PDF). Object Management Group. Archived from the original (PDF) on September 15, 2011. Retrieved November 9, 2016.
  • ^ "DDS Interoperability Demo December 2010" (PDF). Real-Time Innovations, Inc. December 11, 2010. Retrieved November 9, 2016.
  • ^ 2011, March 2011, https://community.rti.com/content/presentation/omg-dds-interoperability-demo-2011
  • ^ 2012, March 2012, https://community.rti.com/content/presentation/omg-dds-interoperability-demo-2012
  • ^ 2013, March 2013, http://www.slideshare.net/GerardoPardo/dds-interoperability-demo-2013-washington-dc
  • ^ "DDS Interoperability Demonstration". video. Real-Time Innovations. December 14, 2010. Archived from the original on 2014-01-07. Retrieved November 9, 2016.
  • ^ a b "The Real-time Publish-Subscribe Wire Protocol DDS Interoperability Wire Protocol Specification (DDSI-RTPS)". May 2019. Retrieved October 28, 2019.
  • ^ "Data Distribution Service (DDS), Version 1.0". Object Management Group. December 2, 2004. Retrieved November 9, 2016.
  • ^ "Data Distribution Service (DDS), Version 1.1". December 4, 2005. Retrieved November 9, 2016.
  • ^ "Data Distribution Service (DDS), Version 1.2". January 1, 2007. Retrieved November 9, 2016.
  • ^ "Data Distribution Service (DDS), Version 1.4". April 10, 2015. Retrieved November 9, 2016.
  • ^ US Patent US8874686
  • ^ US Patent US8671135
  • ^ US Patent US8150988
  • ^ US Patent US9015672
  • ^ DDS for Lightweight CCM (dds4ccm), Version 1.1, formal/2012-02-01, February 2012, http://www.omg.org/spec/dds4ccm/1.1/PDF/
  • ^ Programming languages — C++, 15 October 2003, ISO/IEC 14882, http://www.iso.org/iso/catalogue_detail.htm?csnumber=38110
  • ^ DDS-PSM-Cxx: ISO/IEC C++ 2003 Language DDS PSM, Version ptc/2011-01-02, January 2011, http://www.omg.org/spec/DDS-PSM-Cxx/1.0/Beta1/PDF
  • ^ Extensible and Dynamic Topic Types for DDS (DDS-XTypes), 1.0, formal/2012-11-10, November 2012, http://www.omg.org/spec/DDS-XTypes/1.0/PDF
  • ^ UML Profile for Data Distribution, version: 1.0, http://www.omg.org/cgi-bin/doc?ptc/10-05-17.pdf
  • ^ DDS-Java: Java 5 Language PSM for DDSVersion 1.0, ptc/2012-12-01, March 2013 http://www.omg.org/spec/DDS-Java/1.0/Beta3/PDF
  • ^ "Interface Definition Language (IDL), Version 3.5". OMG. March 1, 2014. Archived from the original on January 21, 2017. Retrieved November 9, 2016.
  • ^ "About the DDS For Extremely Resource Constrained Environments Specification Version 1.0". www.omg.org. Retrieved 2021-03-12.
  • ^ "About the RPC Over DDS Specification Version 1.0". www.omg.org. Retrieved 2021-03-12.
  • ^ "DDS Data Local Reconstruction Layer (DDS-DLRL)". April 2015. Retrieved November 9, 2016.


  • Retrieved from "https://en.wikipedia.org/w/index.php?title=Data_Distribution_Service&oldid=1227940784"

    Categories: 
    Computer standards
    Message-oriented middleware
    Hidden categories: 
    Articles with short description
    Short description matches Wikidata
    Articles with a promotional tone from July 2020
    All articles with a promotional tone
    Articles lacking reliable references from July 2014
    All articles lacking reliable references
    All articles with unsourced statements
    Articles with unsourced statements from October 2019
    Articles with unsourced statements from January 2024
     



    This page was last edited on 8 June 2024, at 16:29 (UTC).

    Text is available under the Creative Commons Attribution-ShareAlike License 4.0; additional terms may apply. By using this site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia Foundation, Inc., a non-profit organization.



    Privacy policy

    About Wikipedia

    Disclaimers

    Contact Wikipedia

    Code of Conduct

    Developers

    Statistics

    Cookie statement

    Mobile view



    Wikimedia Foundation
    Powered by MediaWiki