177 lines
12 KiB
Plaintext
177 lines
12 KiB
Plaintext
= Entaxy
|
||
:imagesdir: .
|
||
:hardbreaks:
|
||
|
||
Entaxy - шина, которую можно конфигурировать извне с помощью графического интерфейса или API, состоящая из модулей:
|
||
|
||
image::Entaxy.png[]
|
||
|
||
== *Управленческий слой(core):*
|
||
|
||
=== basic-auth
|
||
|
||
модуль, отвечающий за аутентификацию в шине. Tак же занимается хранением, созданием, редактированием и удалением учетных записей.
|
||
|
||
xref:core/auth/Authorization.adoc[Более полную информации о basic-auth найдете по этой ссылке]
|
||
|
||
_Для разработчиков:
|
||
-имеет Api, который занимается Crud операциями,
|
||
-хранит учетные записи в базе данных,
|
||
-предоставляет файл с актуальной информацией для nginx,
|
||
-выставляет interсeptor для аутентификации в других сервисах,
|
||
-выставляет interсeptor для определения принадлежности аккаунта определённой системе._
|
||
|
||
|
||
=== permission
|
||
|
||
модуль, отвечающий за управление правами доступа.
|
||
|
||
xref:core/permission/SOAP-service-Permission-management.adoc[Более полную информации о permission найдете по этой ссылке]
|
||
|
||
_Для разработчиков:
|
||
-имеет Api, который занимается Crud операциями
|
||
- хранит права в базе данных,
|
||
-(camel)компонент, который используется в маршрутах, для проверки возможности отправки из системы a в систему b.
|
||
-выставляет interсeptor для авторизации в служебных сервисах._
|
||
|
||
|
||
=== system-management-api
|
||
|
||
модуль, отвечающий за создание систем и разнообразных коннекторов. (коннекторы бывают разных типов, будет описано далее)
|
||
|
||
xref:core/system-managment/Users-manual-System-management.adoc[Более полную информации о system-management найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-имеет Api, который занимается Crud операциями
|
||
-хранит параметры в базе данных,
|
||
-генерирует профиля и коннекторы на основе переданных через Api параметров и деплоит их через репозиторий nexus или файловую систему и cellar (блок Deployer) в шину.
|
||
-также имеет возможность Crud прав доступа над учетными записями систем.
|
||
__
|
||
|
||
=== system-registry
|
||
|
||
модуль, осуществляющий поддержку динамического управления профилями систем(профиль - это отражение параметров системы в шине)
|
||
|
||
__Для разработчиков:
|
||
-хранит информацию о системах в базе данных,
|
||
-(camel)компонент, который используется в маршрутах для определения нужной системы и коннектора для отправки сообщения в нее.
|
||
__
|
||
|
||
=== system-group-registry
|
||
|
||
модуль, осуществляющий поддержку динамического управления группами систем, которые определяют логику отправки в необходимую систему в определенной группе.
|
||
|
||
__Для разработчиков:
|
||
-хранит информацию о группах в базе данных,
|
||
-(camel)компонент, который используется в маршрутах для определения нужной системы из группы.
|
||
__
|
||
|
||
=== events
|
||
|
||
модуль, для работы с топиками(по схеме Publisher (издатель)-Subscriber (подписчик)) для систем.
|
||
|
||
xref:core/topic/Topic-management-Rest-service.adoc[Более полную информации о events найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-хранит информацию о топиках в базе данных,
|
||
-имеет Api(Rest), который занимается Crud операциями
|
||
__
|
||
|
||
=== schema
|
||
|
||
модуль, осуществляющий хранение всех схем, через которые делаются преобразования сообщений, валидация, поднятие сервиса в шине.
|
||
|
||
xref:core/schema/Schema.adoc[Более полную информации о schema найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-имеет Api, который занимается Crud операциями
|
||
-хранит информацию о загруженных схемах в базе данных,
|
||
-(camel)компонент, который используется в маршрутах для валидации xml через xsd, которую загрузили в бд.
|
||
-service, который подключается к xslt компоненту для подгрузки xsl из бд
|
||
-service, который подключается к cxf компоненту для подгрузки xsd и wsdl из бд
|
||
__
|
||
|
||
=== bridge
|
||
|
||
модуль, осуществляющий передачу сообщений в другую шину.
|
||
|
||
xref:core/bridge/Bridge-Description-and-Configuration.adoc[Более полную информации о bridge найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-знает о всех подключенных шинах и их именах в рамках всей системы
|
||
-осуществляет передачу сообщений через artemis, также получает сообщения из другой шины.
|
||
-в перспективе будет создан компонент который по названию будет определять в какую шину отправить, а не напрямую через очереди, как это сделано сейчас.
|
||
__
|
||
|
||
=== Error Handler
|
||
|
||
модуль, осуществляющий за обработку ошибок в шине.
|
||
|
||
Централизованный обработчик ошибок для формирования кодов ошибок, их синхронного возврата клиенту и для асинхронного дублирования более подробного описания ошибки (для клиента и для Центральной Базы Интеграции).
|
||
|
||
xref:core/exception/Centralized-error-handler.adoc[Более полную информации о централизованном обработчике ошибок найдете по этой ссылке]
|
||
|
||
xref:core/exception/Error-description.adoc[Более полную информации о классификации ошибок найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-знает о всех подключенных шинах и их именах в рамках всей системы
|
||
-осуществляет передачу сообщений через artemis, также получает сообщения из другой шины.
|
||
-в перспективе будет создан компонент, который по названию будет определять в какую шину отправить, а не напрямую через очереди, как это сделано сейчас.
|
||
__
|
||
|
||
=== Deployer
|
||
|
||
набор модулей осуществляющих работу с бандлами
|
||
|
||
xref:core/deployer/deployer-common.adoc[Более полную информации о Deployer найдете по этой ссылке]
|
||
|
||
__Для разработчиков:
|
||
-deployer-api - интерфейс репозитория для хранения артефактов
|
||
-file-system-deployer - реализация репозитория в папке
|
||
-nexus-deployer - реализация репозитория в Sonartype Nexus
|
||
-cellar-deployer - система управления бандлами через Apache Cellar
|
||
__
|
||
|
||
== Также как вспомогательные инструменты используется следующие модули:
|
||
|
||
_сellar_ - модуль для загрузки сгенерированных blueprint в шину(в несколько карафов).
|
||
_ignite_ - модуль для создания распределенного хранилища ключ-значение.(используется для более быстрой работы некоторых компонентов, которым нужно хранилище)
|
||
_liquibase_ - модуль для поддержки актуальной схемы бд.
|
||
|
||
== Клиентский слой
|
||
|
||
_US_ - универсальный коннектор, через который можно отправлять сообщения в другие системы.
|
||
_(делится на обычный и служебный)_
|
||
xref:connectors/uniform-exchange-service/uniform-exchange-service.adoc[Универсальный сервис]
|
||
|
||
_file-connector_ - коннектор, который сообщения для определенной системы отправляет с помощью файла(получая сообщение, проводит необходимые преобразования, нпрм архивацию, и складывает в определенную папку).
|
||
|
||
_db-connector_ - коннектор, который осуществляет обмен сообщениями с системой через бд. (сообщение полученное из другой системы конвертируется в запись в бд, и для отправки сообщения в шину необходимо сделать запись в бд)
|
||
|
||
xref:connectors/create_new_connectors.adoc[Информация о создании новых коннекторов]
|
||
|
||
image::connectors/db-connector/deployment_schema.png[]
|
||
|
||
_nsi_ - soap коннектор, который был поднят с помощью клиентской wsdl и работает по специальной схеме, определенной клиентом с помощью бд.
|
||
_big-packets-connector_ - soap коннектор, через который можно отправлять сообщения в другие системы, предназначенный для отправки больших сообщений, которые отправляются по частям.
|
||
|
||
=== Необходимые для шины внешние модули
|
||
|
||
nginx(опционально) - балансировщик нагрузки, также занимается предварительной аутентификацией.
|
||
nexus(опционально) - необходим для хранения и динамической развертки блюпринтов.
|
||
db(поддерживается mssql и postgresql) esb_entaxy - необходима для хранения служебных данных(связанных с настройкой маршрутов в шине).
|
||
db(поддерживается mssql и postgresql) cache - необходима для хранения временных данных, связанных с определенным сообщением.
|
||
artemis - брокер сообщений.
|
||
file-storage(nfs) - необходим для работы сервиса больших пакетов, nginx и тд.
|
||
|
||
=== Схема прохождения пакета
|
||
|
||
Для разработчиков:
|
||
|
||
image::connectors/Message.png[]
|
||
|
||
_Все сообщения отправляемые в шину будут отправляться из входного коннектора в выходную точку профиля._
|
||
|
||
Общее описание Entaxy:
|
||
|
||
xref:core/Common-description-of-the-transport-layer.adoc[Общее описание Entaxy] |