Методы и средства инженерии программного обеспечения

       

Система CORBA и средства описания объектов и компонентов


Архитектура CORBA (Common Object Request Broker Architecture) предоставляет  распределенный обмен данных с помощью специальных объектов–брокеров ORB (Object Request Broker), применяется  для обработки запросов. Эта технология позволяет прикладной программе запрашивать  сервисы другой программы, вызывая методы ее удаленных объектов. Для реализации взаимодействия объекта–брокера и программы (клиента и сервиса) используется  язык интерфейса IDL (Interface Definition Language). JAVA включает ORB и компилятор idltojava, который генерирует код по IDL спецификациям [8 –10].

Работа в системе  CORBA сводится к генерации JAVA файлов  на основе  IDL файла интерфейса для стороны сервера или для стороны клиента или для обеих. Со стороны клиента требуется специфическая IOR форма (Interoperable Object Reference), которая поддерживает именование  сервера. CORBA использует браузер для просмотра имен сервисов, генерации  кода и вставки его в файл класса клиента. Со стороны сервера дополняется код, который связывает экземпляры сервентов с именами сервисов. Браузер может сгенерировать этот код и вставить его в файл класса сервера. IDL файл компилируется и полученная программа запускается для выполнения.

В системе CORBA  имеются следующие  шаблоны  интеграции

компонентов:

– Client class для вызова метода, который будет выполнен сервером.

– Stub class для конвертации  метода,  инициирующего работу клиента в Wire формате, используемом  при связывании в сети на стороне клиента;

– ORB class управляет  методами передачи данных и вызовами методов между процессами;

– Implementation class содержит деловую логику сервера, экземпляр этого класса сервент регистрируется в ORB и может  использоваться клиентом для  запуска другого процесса;

– Server class создает сервент и ссылку IOR, доступную ему, которую он записывает в  стандартный выходной  файл;

– Skeleton class конвертирует инициирующий метод с Wire форматом с помощью ORB брокера в формат, который может прочитать экземпляр сервента.

Для реализации ПИК типа CORBA компоненты используют как шаблон,  так и мастер создания CORBA компонентов. Система  CORBA предлагает шаблоны для создания и реинженерии компонентов.

Шаблон поддержки работы адаптера POA (Portable Object Adapter)  является  корнем каждой иерархии серверов и доступен разным ORB. Адаптер порождает следующие типы объектов: пустой сервер (Empty), основной класс сервер (ServerMain), класс клиент (ClientMain) и простой Simple (сервер с минимальными инициированными элементами).

При использовании мастера инициализации CORBA компонентов пользователь должен использовать три параметра (value, title, type), каждый из которых задается переменной строкового типа, значения которого понимает мастер. Например:

<server– binding name = ‘Proprietary Binder’ template–tag = ‘SERVER_BINDING’>

<wizard requires–value = ‘/* FFJ_COBRA_TODO_SERVER_NAME*/’

title = ‘Server name:’ type = ‘string’/>



Содержание раздела