Corba Fundamentals   «Prev  Next»
Lesson 7 A functional view of the OMA
Objective Object Management architecture functionality

Object Management Architecture Functional View

The "Object Management Architecture" (OMA) was a significant part of the Common Object Request Broker Architecture (CORBA) specification, developed by the Object Management Group (OMG). However, its use has significantly declined over the years, especially as newer technologies have emerged.
  • Historical Use: OMA was designed to provide a framework for distributed computing, allowing different systems to interact regardless of their underlying hardware or software. It was particularly prominent in the 1990s, but as noted in various sources, its complexity and the rise of alternative technologies have led to its diminished use.
  • Current Status: By the mid-2000s, technologies like SOAP, RESTful services, and more recently, microservices architectures, have largely eclipsed CORBA and by extension, OMA. While CORBA itself is sometimes still used in niche areas or legacy systems, especially in industries like telecommunications or aerospace for specific projects, the overarching OMA framework isn't commonly referenced or implemented in modern distributed systems.
  • Reasons for Decline: Complexity: CORBA, including OMA, was criticized for its complexity in implementation and use, which made it less appealing for new system designs.
  • Emergence of Alternatives: More straightforward protocols and architectures like REST, SOAP, and later gRPC, have provided simpler, more flexible solutions for distributed systems.
  • Support and Ecosystem: The ecosystem around CORBA has shrunk, with less support from major vendors and fewer developers with expertise in the technology.

In summary, while elements of the Object Management Architecture might still exist in very specific or legacy applications, it is not a widely adopted or commonly used framework in contemporary software development environments.

How Components of the OMA commonly function

Understand how the components of the OMA commonly function. The OMA is designed to reuse functionality wherever possible. This is most obvious at the fundamental ORB level, where the ORB is used by all components as a communications mechanism. In addition, since the CORBAservices provide fundamental object-level functionality, components of the CORBAservices are reused in much of the CORBAfacilities specifications and even frequently reused within the CORBAservices specifications themselves. In fact, there are no usage restrictions and any part of the OMA may make use of existing OMA components.
Functional overview of the OMA consisting of Objects, interfaces, facilities, services
Functional overview of the OMA consisting of Objects, interfaces, facilities, services

The diagram above roughly depicts how specific portions of the OMA commonly function. Even though there are no component usage restrictions, reuse usually takes place at successively higher levels. What this means architecturally is that CORBA applications developers will make use of both CORBAfacilities and CORBAservices, while the CORBAfacilities will make use of many of the CORBAservices, and all of the components will make use of the ORB to provide CORBA communication. The bulk of the remaining concepts that make up the CORBA specification are based upon the simple but powerful Object Management Architecture (OMA) and the fundamental request/reply services provided by the ORB. But before we begin looking deeper into CORBA, we will take an opportunity in the next lesson to analyze our fundamental understanding of CORBA.

Concepts and Terminology

CORBA provides platform-independent programming interfaces and models for portable distributed object-oriented computing applications. Its independence from programming languages, computing platforms, and networking protocols makes it highly suitable for the development of new applications and their integration into existing distributed systems. Like all technologies, CORBA has unique terminology associated with it. Although some of the concepts and terms are borrowed from similar technologies, others are new or different. Understanding these terms and the concepts behind them is key to having a firm grasp of CORBA itself. The most important terms in CORBA are explained in the following list. A CORBA object is a "virtual" entity capable of being located by an ORB and having client requests invoked on it. It is virtual in the sense that it does not really exist unless it is made concrete by an implementation written in a programming language. The realization of a CORBA object by programming language constructs is analogous to the way virtual memory does not exist in an operating system but is simulated using physical memory. A target object, within the context of a CORBA request invocation, is the CORBA object that is the target of that request. The CORBA object model is a single-dispatching model in which the target object for a request is determined solely by the object reference used to invoke the request.
A client is an entity that invokes a request on a CORBA object. A client may exist in an address space that is completely separate from the CORBA object, or the client and the CORBA object may exist within the same application. The term client is meaningful only within the context of a particular request because the application that is the client for one request may be the server for another request.
A server is an application in which one or more CORBA objects exist. As with clients, this term is meaningful only in the context of a particular request. A request is an invocation of an operation on a CORBA object by a client. Requests flow from a client to the target object in the server, and the target object sends the results back in a response if the request requires one.
An object reference is a handle used to identify, locate, and address a CORBA object. To clients, object references are opaque entities. Clients use object references to direct requests to objects, but they cannot create object references from their constituent parts, nor can they access or modify the contents of an object reference. An object reference refers only to a single CORBA object.
A servant is a programming language entity that implements one or more CORBA objects. Servants are said to incarnate CORBA objects because they provide bodies, or implementations, for those objects. Servants exist within the context of a server application. In C++, servants are object instances of a particular class. The definitions of these terms will be refined in later chapters, but these definitions will be sufficient for understanding the CORBA features described in the next section.

SEMrush Software