Logo    
Деловая газета CitCity.ru CITKIT.ru - все об Open Source Форумы Все публикации Учебный центр Курилка
CitForum    CITForum на CD    Подписка на новости портала Море(!) аналитической информации! :: CITFORUM.RU
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

24.05.2017

Google
WWW CITForum.ru
С Новым годом!
2007 г.

Corba: ушла, но (будем надеяться) не забыта

Терри Коатта
Перевод: Сергей Кузнецов
Оригинал: Terry Coatta. Corba: Gone But (Hopefully) Not Forgotten, ACM Queue, Volume 5, Number 4, May/June 2007.

Чудес не бывает, и уроки прошлого применимы и сегодня

В июньском номере Queue за 2006 г. Мичи Хеннинг (Michi Henning) представил очень хорошую концентрированную историю CORBA и привел обсуждение того, как некоторые технические ограничения этой технологии способствовали ее краху. Хотя эти ограничения, несомненно, содействовали закату CORBA, имеется широко распространенное мнение, что основной причиной явилось доминирующее влияние Web-сервисов. Это мнение подкрепляется верой в то, что доминирующее положение Web-сервисов в области распределенного компьютинга свидетельствует о техническом превосходстве этой технологии над предшествовавшими ей технологиями, такими как CORBA и DCOM.

Проработав в области распределенных систем довольно много лет – начиная с того времени, когда построение распределенной системы в действительности означало упаковку бит в пакеты UDP с использованием любовно сделанного вручную кода на языке C, – я считаю это предположение безосновательным. Хуже того, оно свидетельствует о нежелании по достоинству оценивать те аспекты предшествующих систем, которые были хорошо продуманы и разработаны. Это является симптомом менталитета «серебряной пути», когда технология Web-сервисов рассматривается как радикальный отказ от прошлого, позволяющий окончательно устранить сложность разработки и построения распределенных систем.

На самом ли деле Web-сервисы отличаются от предшествующих систем? Одним из значительных преимуществ, приписываемых технологии Web-сервисов, является то, что она нацеливается на поддержку сервис-ориентированной архитектуры (Service Oriented Architectures, SOA). Близость этих понятий подчеркивает наличие слова «сервис» в названиях их обоих. «Ориентация на сервисы» часто противопоставляется стилю «мелкоструктурных» (fine-grain) распределенных объектов, который считается определяющей характеристикой систем, основанных на CORBA. Конечно, верно, что в CORBA обеспечивается распределенный доступ на уровне индивидуальных объектов. Однако следует заметить, что в CORBA также поддерживаются рекурсивно определяемые структуры данных, которые позволяют достаточно просто обмениваться сложными структурами данных, передаваемыми по значению.

В середине 1990-х я работал в составе группы, которая проектировала и разрабатывала основанную на CORBA систему, обеспечивающую с использованием этой возможности обмен информацией об управлении разработкой и сопровождением программного обеспечения. Мы спроектировали структуру данных CORBA, представляющую дерево узлов. У каждого узла имелось имя, значение и некоторые другие атрибуты. В нем также содержались дочерние узлы, каждый из которых обладал такой же структурой. Конечно, у листовых узлов потомки отсутствовали. Эту структуру было относительно просто представить на языке CORBA IDL с использованием конструкций struct, union и array. Любое дерево, состоящее из таких узлов, можно было легко передать посредством вызова метода в CORBA – подсистема поддержки времени выполнения производила сериализацию дерева и передавала его массовым образом получателю. Кроме того, такое дерево вообще не содержало ссылок на объекты и использовалось исключительно для обмена информацией по значению. Наконец, можно заметить, что структура и содержимое этого дерева не случайно напоминают DOM-представление XML-документа.

По моему мнению, этот пример демонстрирует, что хотя CORBA, безусловно, могла поддерживать мелкоструктурные объектные архитектуры, она никоим образом не навязывала применение этого стиля. Безусловно, простота реализации мелкоструктурной архитектуры могла соблазнять разработчиков, обладающих недостаточным опытом построения распределенных систем. Но это вовсе не означает, что мелкоструктурные объекты полностью бесполезны. При использовании мультипроцессорной системы, когда требования к пропускной способности и задержке существенно отличаются от соответствующих требований к приложению, распределенному в Internet, мелкоструктурные объекты могут обладать некоторой привлекательностью.

И в этом состоит суть проблемы. Когда мы создавали упоминавшуюся выше систему, мы могли выбрать подход с определением множества объектных интерфейсов и передачей между ними ссылок. Но мы знали, что к информации об управлении, в основном, будет требоваться массивный доступ, и это лишало всякого смысла передачу информации по кусочкам путем многократного вызова методов. Вместо того чтобы понадеяться на то, что эту нашу проблему каким-то образом решит CORBA, мы решили сами выбрать те элементы CORBA, которые обеспечивали требуемое нам поведение. Мы создали «сервис-ориентированное» решение, потому что это имело смысл.

Применение Web-сервисов не гарантирует построение хорошей распределенной системы, а использование CORBA не обязательно приводит к созданию плохой системы. Web-сервисы не могут волшебным образом предоставить системе возможность эффективно справиться с ограничениями пропускной способности и задержки. Эта технология не может устранить трудности, возникающие из-за частичных отказов и зависимостей в системах, которые могут становиться временно недоступными. К счастью, люди проектируют и создают распределенные системы на протяжении многих лет, часто используя технологии, подобные CORBA, DCOM, и более ранние технологии. Не надо думать, что вся эта работа вытесняется волшебством Web-сервисов, поскольку чудес на свете не бывает, а уроки прошлого применимы и сегодня.

Терри Коатта (Terry Coatta) является членом редакционного совета ACM Queue. Он работает менеджером по продукции компании Vitrium Systems Inc., которая производит программное обеспечение для отслеживания и контроля доступа к PDF-документам. В прошлом он занимал должности вице-президента по разработкам в компании Silicon Chalk, создававшей программное обеспечение реального времени для использования в высшей школе, и директором по разработке распределенных систем в Open Text Corporation. Он получил степень PhD в области компьютерных наук в University of British Columbia.

Размещение рекламы — тел. +7 495 4119920, ICQ 232284597

Подписка на новости IT-портала CITForum.ru
(библиотека, CITKIT.ru, CitCity)

Новые публикации:

24 декабря

CITKIT.ru:

  • Новогодние поздравления
  • Сергей Кузнецов. Цикл Операционные системы: Ностальгия по будущему:

  • Алексей Федорчук. OpenSolaris 2008.11 Release

  • Сергей Голубев:

  • Евгений Чайкин aka StraNNik (Блогометки):

    17 декабря

  • С.Д.Кузнецов. Базы данных. Вводный курс

    10 декабря

    CITKIT.ru:

  • OpenSolaris 2008.11 Release

  • Альтернативные ОС: две грустные истории (С.Кузнецов)
  • Nokia N810 — доведение до ума
  • CitCity:

  • Платформа 2009: заоблачные перспективы Microsoft

    4 декабря

  • Лекция С.Д.Кузнецова Понятие модели данных. Обзор разновидностей моделей данных

    CITKIT.ru:

  • OpenSolaris 2008.11 Release. Первые впечатления

  • Linux vs FreeBSD: продолжим "Священные войны"?

  • Nokia N810 as is

  • Индульгенция для FOSS

  • Друзья СПО'2008

    26 ноября

  • Нечеткое сравнение коллекций: семантический и алгоритмический аспекты

    CitCity:

    CITKIT.ru:

  • Глава из книги А.Федорчука
    Сага о FreeBSD:
  • 19 ноября

  • Проблемы экономики производства крупных программных продуктов

  • Язык модификации данных формата XML функциональными методами

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    Заметки к книге:

  • FreeBSD: монтирование сменных устройств и механизм HAL
  • Текстовый редактор ee

    12 ноября

  • Правило пяти минут двадцать лет спустя, и как флэш-память изменяет правила (Гоц Грейф, перевод: Сергей Кузнецов)

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:
  • OSS в России: взгляд правоведа (В.Житомирский)

  • Новая статья из цикла С.Голубева "Железный марш":

    29 октября

  • О некоторых задачах обратной инженерии

  • Веб-сервисы и Ruby

  • Тестирование web-приложений с помощью Ruby

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

  • PuppyRus Linux - беседа с разработчиком (С.Голубев)

  • Сергей Кузнецов. Заметка не про Linux

    22 октября

  • Обзор методов описания встраиваемой аппаратуры и построения инструментария кросс-разработки

    CITKIT.ru:

  • Сергей Кузнецов. Почему я равнодушен к Linux

  • Глава из книги А.Федорчука
    Сага о FreeBSD:
  • Что надо иметь
    3. Базовые познания

    CitCity:

  • Управление IT-инфраструктурой на основе продуктов Microsoft

    15 октября

  • Методы бикластеризации для анализа интернет-данных

    CitCity:

  • Разъемы на ноутбуках: что они дают и зачем их так много?
  • AMD Puma и Intel Centrino 2: кто лучше?

    CITKIT.ru:

  • Новый цикл статей С.Голубева
    Железный марш:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    8 октября

  • Автоматизация тестирования web-приложений, основанных на скриптовых языках
  • Опыт применения технологии Azov для тестирования библиотеки Qt3

    Обзоры журнала Computer:

  • SOA с гарантией качества
  • Пикоджоуль ватт бережет
  • ICT и всемирное развитие

    CitCity:

  • Пиррова победа корпорации Microsoft

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    Статья из архива:

  • Я живу в FreeBSD (Вадим Колонцов)

    Новые Блогометки:

  • Перекройка шаблона Blogger или N шагов к настоящему
  • Blogger. Comment style
  • Screenie или глянцевый снимок экрана

    2 октября

    CITKIT.ru:

  • Сага о FreeBSD (А. Федорчук)

    Zenwalk: пакет недели

  • Банинг — интеллектуальное развлечение (С.Голубев)

    CitCity:

    25 сентября

  • Клермонтский отчет об исследованиях в области баз данных

    CITKIT.ru:

  • Пользователям просьба не беспокоиться... (В.Попов)

  • Снова про ZFS: диск хорошо, а два лучше
  • Командная оболочка tcsh (А.Федорчук)

    Zenwalk: пакет недели

    17 сентября

  • T2C: технология автоматизированной разработки тестов базовой функциональности программных интерфейсов
  • Технология Azov автоматизации массового создания тестов работоспособности

    CITKIT.ru:

  • FreeBSD: ZFS vs UFS, и обе-две — против всех (А.Федорчук)

    Zenwalk: пакет недели

  • Дачнет — практика без теории (С.Голубев)

    10 сентября

  • За чем следить и чем управлять при работе приложений с Oracle
  • Планировщик заданий в Oracle
    (В.Пржиялковский)

    CITKIT.ru:

  • Microsoft: ответный "боян" (С.Голубев)

  • Причуды симбиоза, или снова "сделай сам" (В.Попов)

  • Файловые системы современного Linux'а: последнее тестирование
  • Zsh. Введение и обзор возможностей
    (А.Федорчук)

    Описания пакетов Zenwalk: Zsh, Thunar, Thunar-bulk-rename, Xfce4-places-plugin, Xfce4-fsguard-plugin

    Блогометки:

  • Google Chrome
  • Лончер для ASUS Eee PC 701

    3 сентября

    CITKIT.ru:

  • Заметки о ядре (А.Федорчук):

    Добавлены описания пакетов Zenwalk: Galculator, Screenshot, Gnumeric, Pidgin

    В дискуссинном клубе:

  • И еще о Википедии и Google Knol

  • Лекция для начинающего линуксоида (С.Голубев)

    26 августа

  • Транзакционная память (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • Открыт новый проект Zenwalk: пакет недели

  • Статья Текстовые процессоры и их быстродействие: конец еще одной легенды?

    21 августа

    CITKIT.ru:

  • Почему школам следует использовать только свободные программы (Ричард Столлман)
  • Беседа Сергея Голубева с учителем В.В.Михайловым

  • Википедия или Гуглезнание? Приглашение к обсуждению (Алексей Федорчук)
  • Народная энциклопедия от Google (StraNNik)

  • Обзор Mandriva 2009.0 Beta 1 Thornicrofti
  • Новичок в Линукс: Оптимизируем Mandriva 2008.1

  • Книга Zenwalk. Приобщение к Linux:

    13 августа

    CitCity:

  • Мирный Atom на службе человеку. Обзор платы Intel D945GCLF с интегрированным процессором
  • Обзор процессоров Intel Atom 230 на ядре Diamondville

  • iPhone - год спустя. Скоро и в России?

    CITKIT.ru:

  • Интермедия 3.4. GRUB: установка и настройка (из книги Zenwalk. Приобщение к Linux)

    6 августа

  • СУБД с хранением данных по столбцами и по строкам: насколько они отличаются в действительности? (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • Интермедия 2.2. Что неплохо знать для начала (из книги Zenwalk. Приобщение к Linux)

  • И снова про шрифты в Иксах (А.Федорчук)

  • 20 самых быстрых и простых оконных менеджеров для Linux

  • Дело о трех миллиардах (С.Голубев)

    30 июля

  • OLTP в Зазеркалье (Пересказ: С. Кузнецов)

    CitCity:

  • Будущее BI в облаках?
  • Тиражные приложения и заказная разработка. Преимущества для заказчика
  • Дискуссия со сторонниками заказной разработки

    CITKIT.ru:

  • Новые главы книги Zenwalk. Приобщение к Linux:
  • Глава 8. Пакеты: средства установки, системы управления, системы построения
  • Глава 9. Zenwalk: репозитории, пакеты, методы установки

    23 июля

    CITKIT.ru:

  • Все против всех. 64 vs 32, Intel vs AMD, tmpfs vs ext3
  • Две головы от Intel

  • Zenwalk: обзор штатных приложений (глава из книги "Zenwalk. Приобщение к Linux")

  • Нормально, Григорий...

    16 июля

    Обзоры журнала Computer:

  • Перспективы и проблемы программной инженерии в XXI веке
  • Большие хлопоты с большими объемами данных
  • Перспективы наноэлектроники

    CITKIT.ru:

  • Интермедия о лицензиях (А.Федорчук. "Zenwalk. Приобщение к Linux")

  • Есть ли будущее у KDE?

  • Linux в школе: альтернативный вариант в задачах

  • Шифр (приключения агента Никодима)

    10 июля

    CITKIT.ru:

  • Новые разделы книги А. Федорчука Zenwalk. Приобщение к Linux:
  • Интермедия вступительная. Linux или GNU/Linux? Как вас теперь называть?
  • Глава 5. Среда Xfce
  • Глава 6. Xfce: приложения и плагины

  • ZUR (Zenwalk User Repository) FAQ

    2 июля

  • Персистентность данных в объектно-ориентированных приложениях (С. Кузнецов)

    CITKIT.ru:

  • Новые разделы книги А. Федорчука Zenwalk. Приобщение к Linux:
  • Интермедия 1.2. Дорога к Zenwalk'у. Период бури и натиска
  • Интермедия 3.3. Немного о Linux'е и "железе"
  • Глава 4. Настройка: инструментами и руками
  • Интермедия 4.1. Zenpanel и конфиги: поиски корреляции

  • Интервью с Жан-Филиппом Гийоменом, создателем дистрибутива Zenwalk

  • Linux в школе: первые итоги (С. Голубев)

    25 июня

    CITKIT.ru:

  • Zenwalk. Приобщение к Linux (А. Федорчук)

  • Логика и риторика (С.Голубев)

  • Технология Tru64 AdvFS

  • Ханс Райзер предлагает отвести полицейских к телу Нины

    18 июня

  • Проекты по управлению данными в Google (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • ОС и поддержка "железа": мифы и реальность (А. Федорчук)

  • Linux в школе: другие дистрибутивы

  • Пинок (С. Голубев)

    4 июня

  • Ландшафт области управления данными: аналитический обзор (С. Кузнецов)

    CITKIT.ru:

  • Linux в школе: слово заинтересованным лицам

  • SlackBuild: пакеты своими руками

  • Linux от компании Novell. Установка и обзор openSUSE Linux

    Все публикации >>>




  • IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

    Информация для рекламодателей PR-акции, размещение рекламы — тел. +7 495 4119920, ICQ 232284597 Пресс-релизы — pr@citcity.ru
    Послать комментарий
    Информация для авторов
    Rambler's Top100 TopList liveinternet.ru: показано число просмотров за 24 часа, посетителей за 24 часа и за сегодня This Web server launched on February 24, 1997
    Copyright © 1997-2000 CIT, © 2001-2007 CIT Forum
    Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...