Шаблон логической централизации - Logic centralization pattern

Логическая централизация это шаблон дизайна, применяется в сервис-ориентированность парадигма дизайна, чье приложение направлено на повышение потенциала повторного использования агностической логики [1] гарантируя, что услуги[2] не содержат избыточной независимой логики и что любая повторно используемая логика должна быть представлена ​​только службой, имеющей наиболее подходящий функциональный контекст.[3][4]

Обоснование

Поскольку разрабатывается все больше и больше сервисов, существует постоянный риск того, что могут быть созданы сервисы с избыточной функциональностью. Хотя применение Нормализация услуг шаблон проектирования действительно помогает устранить эту избыточность, однако наличие одного только набора нормализованных сервисов не гарантирует их повторного использования, как первоначально предполагалось. В случае агностических услуг,[5] эта проблема может серьезно ограничить фактическое повторное использование таких сервисов, потому что команда проекта (команда A) может решить не использовать повторно существующий сервис, например для этого требуются данные, соответствующие сложной схеме, и вместо этого разрабатывается облегченная служба, которая просто выполняет свою работу. В результате одна и та же повторно используемая логика теперь существует с двумя разными сервисами, тогда как существующий сервис должен был развиваться, даже если он не содержал наиболее подходящего варианта функциональности. Этот эффект усиливается, когда другая команда (команда B), надеясь найти функциональность в существующей службе, поскольку граница службы действительно покрывает требуемую функциональность, не может ее найти и вместо этого начинает использовать вновь созданный сервис командой A. Следовательно , реальная возможность повторного использования оригинальной независимой службы падает и в то же время создает управление Проблема в том, что касается обслуживания оригинальных и новых сервисов, потому что теперь многоразовая логика существует децентрализованно.

Чтобы гарантировать, что определенный тип повторно используемой логики решения заключен только в одну конкретную независимую службу, шаблон проектирования «Логическая централизация» требует установления стандартов проектирования, обеспечивающих правильное использование независимых служб. Это дает потребителям услуг уверенность в том, что они получают доступ к функциям через правильный сервис.[6]

использование

Диаграмма А
Диаграмма А
Вместо использования существующей красной службы, Project Team 1 прибегает к созданию новой резервной красной службы, поскольку было легко разработать новую службу, более оптимизированную с учетом их краткосрочных требований.
Диаграмма А
Диаграмма А
При наличии общеорганизационного стандарта проектирования доступ потребителей сервисов к избыточной красной службе, созданной Project Team 2, запрещен, и вместо этого они вынуждены использовать существующую красную службу, созданную Project Team 1. Аналогичным образом, Project Team 3 является Запрещается создавать какие-либо новые службы, функциональность которых соответствует существующей красной службе, в результате чего Project Team 3 использует / развивает существующую красную службу, созданную Project Team 1.

Применение этого шаблона проектирования требует настройки «официальных конечных точек» (сервисов), которые представляют определенный тип функциональности, то есть функциональность, которая относится к определенному типу функциональной области. Доступ к любым другим службам, которые могут предлагать те же функции, запрещен, и только одна служба становится доступной для определенного типа функций.[7] Ограничивая доступ к другим службам, снижается бремя управления, поскольку теперь логика ограничена одной службой. Всякий раз, когда требуется новая функциональность, которая в настоящее время не предлагается ни одной из существующих служб, сначала необходимо проверить функциональные контексты существующих служб, и если новая функциональность попадает под границы уже существующей службы, тогда она должна быть добавленным к этой услуге. Для этого требуется общеорганизационный стандарт, обеспечивающий централизацию логики. Чтобы убедиться, что разработчики сервисов осведомлены о границах сервисов, Централизация метаданных[8] шаблон дизайна может быть применен. Это помогает в создании централизованного хранилища информации о функциональных контекстах и ​​функциях, предоставляемых службами. Шаблон проектирования Logic Centralization при применении вместе с Contract Centralization[9] шаблон проектирования, составляют официальную конечную точку[10] шаблон дизайна. Применение шаблона проектирования Logic Centralization дополнительно помогает в применении Возможность повторного использования сервиса и Возможность компоновки сервисов принципы проектирования, гарантируя, что каждая служба содержит правильный тип многоразовой функциональности, чтобы ее можно было многократно составлять.

Соображения

Чтобы применить этот шаблон проектирования, необходимо убедиться, что все проектные группы на предприятии понимают и соглашаются с надлежащим использованием независимых сервисов и не создают никаких новых сервисов, которые служат только краткосрочным требованиям проекта. Это также может повлиять на время выполнения проекта, поскольку использование существующих независимых сервисов (и их развитие в соответствии с рекомендациями этого шаблона) потребует увеличения времени и усилий. Это связано с тем, что службы в текущем проекте не смогут использовать независимые службы до тех пор, пока не будет изменен их собственный дизайн.

Рекомендации

  1. ^ Логика, которая не относится к конкретному бизнес-процессу и, следовательно, может быть повторно использована для автоматизации нескольких бизнес-процессов
  2. ^ "Услуги". Архивировано из оригинал на 2012-05-01. Получено 2010-03-09.
  3. ^ Тип функциональности, предоставляемой сервисом.
  4. ^ Кану Трипати.Обработка транзакций службы без WS-AtomicTransaction [Online]. Дата обращения: 25 апреля 2010 г.
  5. ^ Сервисы, содержащие агностическую логику
  6. ^ Деннис Висноски.Принципы и модели в Министерстве обороны США В архиве 2010-09-20 на Wayback Machine [Online]. Дата обращения: 25 апреля 2010 г.
  7. ^ Мэтью Дейли.Архитектура программного обеспечения Дизайн Сервис-ориентированные архитектуры (Часть II) В архиве 2011-07-24 на Wayback Machine [Online]. Дата обращения: 25 апреля 2010 г.
  8. ^ Шаблон централизации метаданных
  9. ^ Схема централизации контрактов
  10. ^ Официальный шаблон конечной точки

внешняя ссылка