Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Конспект лекций РСОИ.doc
Скачиваний:
20
Добавлен:
04.11.2018
Размер:
1.93 Mб
Скачать

4.4. Порівняльний аналіз технологій сом і соrва

4.4.1. Основні принципи об'єктних моделей

CORBA і COM багато в чому різні, однак подібні тим, яким чином у них досягається реалізація принципів архітектури проміжного рівня. Це клієнт-серверні технології, у яких функціональність об’єкту надається клієнту за допомогою звертання до абстрактних інтерфейсів. Інтерфейс визначає набір методів, що реалізують функції, притаманні певному класу об'єктів. Інтерфейс дає клієнту можливість тільки викликати той чи інший метод, ховаючи від нього всі деталі його реалізації. Це означає, що реальні дії виконуються в адресному просторі об’єкту, можливо, віддаленого від процесу клієнта. Приховання деталей реалізації дозволяє домогтися злагодженої взаємодії компонентів незалежно від того, де і на якій платформі вони реалізовані і яка мова програмування для цього використовувалася.

В обох технологіях взаємодія між клієнтським процесом і сервером об’єкту, тобто процесом, що породжує й обслуговує екземпляри об’єкту, використовує механізм викликання віддаленої процедури (RPC, remote procedure call). Механізм RPC реалізує схему передавання повідомлень, відповідно до якої в розподіленому клієнт-серверному застосунку процедура-клієнт передає спеціальне повідомлення з параметрами виклику мережею у віддалену серверну процедуру, а результати її виконання повертаються в іншому повідомленні клієнтському процесу.

Щоб реалізувати цю схему, на стороні клієнта і на стороні сервера підтримуються спеціальні компоненти, що мають назву клієнтський і серверний сурогати (client stub і server stub). Щоб викликати ту чи іншу функцію, клієнт звертається до клієнтського сурогату, який упаковує аргументи в повідомлення-запит і передає їх на транспортний рівень з'єднання. Серверний сурогат розпаковує отримане повідомлення і відповідно до переданих аргументів викликає потрібну функцію або потрібний метод об’єкту, якщо мова йде про об'єктний варіант RPC. У СОМ клієнтський сурогат називається proxy, а серверний — stub. У CORBA клієнтський сурогат не має спеціальної назви, а серверний позначають терміном skeleton.

Параметри виклику можуть формуватися у відмінному від серверного мовному й операційному середовищі, тому на клієнтський і серверний сурогати покладаються функції перетворення аргументів і результатів в універсальне, що не залежить від конкретної архітектури, представлення. Тим самим досягається можливість взаємодії клієнта і сервера на різних платформах.

Вихідна модель СОМ була презентована фірмою Мicrosoft у 1993 році як інтеграційна схема для підтримки OLE, технології побудови складних документів в ОС Windows 3.1. Спочатку інфраструктура СОМ дозволяла реалізовувати компоненти, які взаємодіють у рамках одного адресного простору або між процесами на одному комп'ютері, і являла собою фактично засіб динамічної інтеграції двійкових компонентів. Крім OLE, модель СОМ послужила основою таких технологій Microsoft, як монітор транзакцій Microsoft Transaction Server і архітектура інтеграції прикладних компонентів Active.

На відміну від СОМ, архітектура CORBA із самого початку створювалася для розподілених об'єктних систем. Її автором є не окремо взята фірма, а консорціум Object Management Group (зараз у нього входять понад 800 компаній, наприклад, IBM, DEC, HP), що поставила за мету розробити стандартну архітектуру для взаємодії об'єктів у неоднорідному мережевому середовищі.

Ядром архітектури CORBA є брокер об'єктних запитів (Object Request Broker, ORB). Це об'єктна шина, якою у стилі, що нагадує класичний механізм RPC, відбувається взаємодія локальних і віддалених об'єктів. На відміну від СОМ, ORB не спирається безпосередньо на механізм RPC, але працює за тими самим принципами. Крім самого викликання методу віддаленого об’єкту, ORB відповідає за пошук реалізації об’єкту, його підготовку до одержання й оброблення запиту, передаваня запиту і доставку результатів клієнту.

Крім того, CORBA містить у собі кілька груп реалізацій об'єктів, а саме прикладні об'єкти, об'єктні служби, загальні засоби і домени. Прикладні об'єкти (Application Objects) являють собою реалізації об'єктів для конкретних користувацьких застосунків, наприклад, об'єкти для підтримки специфічних бізнесів-процесів. Реалізації об'єктів, що надають загальні для будь-якого обєктно-оріентованного середовища можливості, входять у категорію об'єктних служб (CORBA services): служба імен, служба подій, служба збереження в довгостроковій пам'яті, служба транзакцій і т.ін. Загальні засоби (CORBA facilities) — це реалізації об'єктів, необхідні для великої кількості застосунків, наприклад, підтримка складених документів, потоків завдань і ін. У CORBA є також поняття домена; реалізації об'єктів домена (CORBAdomains) призначені для застосунків вертикальних структур — охорони здоров'я, страхування, фінансового ринку, виробничих галузей і т.ін.