[Up: Design and Implementation of]
[Previous: Evaluation] [Next: Interface Definition]
The Object Management Group (OMG) is a consortium comprised of both companies and institutions, with more than 700 members. Founded in 1989, the focus of the OMG is the continued work on the Object Management Architecture (OMA), an open specification of an infrastructure for distributed objects [62].
The OMG's approach [40] is unique in that it does not publish products, but specifications which are based on the experience of its members. When the need for a new specification arises, a Request for Proposal (RFP) is issued. OMG members can then submit proposals which are discussed in a forum, improved upon, and finally published or rejected. While votes are taken only from members, the resulting documents are freely available on the Internet and can be inspected, commented on and adapted by everyone.
In this process the OMG tries to achieve useful compromises between versatility and complexity. Solutions that have already been implemented are preferred, to avoid overly academic specifications that would be hard or impossible to implement. On the other hand, the discussion and peer review among the many OMG members tries to ensure that such a solution is fit for general use rather than only solving the problems seen by the submitters themselves.
The basic structure of the Object Management Architecture is shown in figure 3.1. The building blocks of the OMA are objects belonging to one of four categories: system-oriented object services (for example, the Naming Service), horizontal common facilities (like collaboration), vertical domain-specific interfaces (like architectures for medical applications or air-traffic control systems) or application-specific interfaces [64].
The key component of the Object Management Architecture is the Object Request Broker, often called ``object bus,'' which allows communication among these objects by directing remote method invocations from client to server.
According to the requirements for a distribution platform as described in section 2.1, means for addressing, synchronization and encoding must be provided. CORBA uses the middleware approach as presented in section 2.4.2 employing three main concepts:
[Previous: Evaluation] [Next: Interface Definition]
[Up: Design and Implementation of]