Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ. Архитектурное решение интеграции баз 1С с использованием брокера. Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit mq
Скачать 252.07 Kb.
|
12.02.2021 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ https://infostart.ru/1c/articles/1383113/ 1/5 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ Публикация № 1383113 Разработка - Системная интеграция - Интеграция При решении задач интеграции баз данных можно использовать различные средства «транспорта» сообщений. Одним из таких механизмов является брокер сообщений «Rabbit MQ». Такие механизмы очередей сообщений удобно использовать для организации обмена между информационными системами с различной структурой данных, когда велик объем передаваемой информации и требуются гарантии успешной доставки сообщений, а также когда поддержание работоспособности иных способов передачи, например через файлы, становиться слишком трудоемким. Брокер сообщений Rabbit MQ широко описан в сети, но 1С пока не имеет штатных механизмов работы с ним, поэтому их приходится дорабатывать. Рассмотрим пример архитектуры 1С с его использованием. Схема выгрузки объектов из базы – источника 1. Для регистрации объектов, подлежащих выгрузки, используем План обмена; собственно, регистрация производится по какому-либо правилу бизнес-процесса, например, при сохранении изменения объекта 1С. 2. Инициализацию выгрузки объектов поручим регламентному заданию; в его обработчике: 2.1. формируем единый для всей выгрузки объектов xdto-контейнер; 2.2. начинаем транзакцию (помимо своей основной функции, она понадобится для снятия управляемых блокировок); 2.3. для каждого вида объекта метаданных вызываем свои процедуры выгрузки объектов, в которых: 2.3.1. из Плана обмена читаем объекты, подлежащие выгрузке; 2.3.2. устанавливаем на эти объекты управляемую блокировку; 2.3.3. на основании xdto-пакета преобразуем объект 1С в объект xdto; 2.3.4. добавляем xdto-объект в единый xdto-контейнер; 2.4. Полученный xdto-контейнер сериализуем в JSON-строку; (/profile/1 (Koder_Line) (/profile/1366685/) Рейтинг: 89 Подписаться (/) Новости (/journal/) Все для 1С (/public/) 1С & Software (/store/) Облачные сервисы (/cloud/) Курсы и вебинары (/courses/) Конференции и митапы (/events/) Видеозаписи (/video/) Биржа труда (/job/) Биржа фриланса (/freelance/) Форум (https://forum.infostart.ru/) Личный кабинет (/profile/index.php Цены на абонемент (/prices/) Техподдержка (/support/) Компания (/about/) 12.02.2021 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ https://infostart.ru/1c/articles/1383113/ 2/5 2.5. Подключаемся к брокеру сообщений Rabbit MQ и записываем в него сообщение с нашей JSON-строкой; 2.6. Для выгруженных объектов 1С снимаем регистрацию в Плане обмена; 2.7. Фиксируем транзакцию и снимаем управляемые блокировки. Результатом является очередь в Rabbit MQ из сообщений о выгруженных объектах 1С. Если объем выгружаемой информации велик, а база активно используется пользователями, то следует позаботиться об уменьшении времени управляемых блокировок. Идти можно следующими путями: локализовать транзакции до выгрузки отдельных видов объектов метаданных; разделить выгрузку отдельных видов метаданных на порции, например, по 100 объектов; отдельно для каждой такой порции устанавливать транзакции и блокировки. (/) Новости (/journal/) Все для 1С (/public/) 1С & Software (/store/) Облачные сервисы (/cloud/) Курсы и вебинары (/courses/) Конференции и митапы (/events/) Видеозаписи (/video/) Биржа труда (/job/) Биржа фриланса (/freelance/) Форум (https://forum.infostart.ru/) Личный кабинет (/profile/index.php Цены на абонемент (/prices/) Техподдержка (/support/) Компания (/about/) 12.02.2021 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ https://infostart.ru/1c/articles/1383113/ 3/5 Схема выгрузки объектов из базы источника Схема загрузки объектов в базе – приемнике (/) Новости (/journal/) Все для 1С (/public/) 1С & Software (/store/) Облачные сервисы (/cloud/) Курсы и вебинары (/courses/) Конференции и митапы (/events/) Видеозаписи (/video/) Биржа труда (/job/) Биржа фриланса (/freelance/) Форум (https://forum.infostart.ru/) Личный кабинет (/profile/index.php Цены на абонемент (/prices/) Техподдержка (/support/) Компания (/about/) 12.02.2021 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ https://infostart.ru/1c/articles/1383113/ 4/5 Схема загрузки объектов в базу-приемник 1. За инициализацию загрузки объектов отвечает Регламентное задание; в его обработчике: 1.1. Подключаемся к очереди сообщений брокера сообщений Rabbit MQ; 1.2. Считываем сообщения в качестве JSON-строк; (/) Новости (/journal/) Все для 1С (/public/) 1С & Software (/store/) Облачные сервисы (/cloud/) Курсы и вебинары (/courses/) Конференции и митапы (/events/) Видеозаписи (/video/) Биржа труда (/job/) Биржа фриланса (/freelance/) Форум (https://forum.infostart.ru/) Личный кабинет (/profile/index.php Цены на абонемент (/prices/) Техподдержка (/support/) Компания (/about/) 12.02.2021 Архитектурное решение интеграции баз 1С с использованием брокера сообщений Rabbit MQ https://infostart.ru/1c/articles/1383113/ 5/5 1.3. По параметрам JSON-сообщения определяем у объектов вид метаданных и вызываем соответствующие процедуры преобразования; в этих процедурах: 1.3.1. На основании xdto-пакетов преобразуем JSON-строки в xdto-объекты; 1.3.2. Преобразуем xdto-объекты в объекты 1С; 1.3.3. Сохраняем объекты 1С в базе 1С. Результатом является запись в базе-приемнике объектов 1С переданных из баз-источников. Итог Мы рассмотрели пример архитектуры 1С для выгрузки/загрузки объектов с использованием брокера сообщений Rabbit MQ. Описанная архитектура универсальна и не зависит от вида используемой конфигурации 1С. Механизм можно использовать в различных интеграционных решениях, в т.ч. для передачи данных между разнородными системами (в силу использования универсального JSON-формата). Специальные предложения Свернуть все (/) Новости (/journal/) Все для 1С (/public/) 1С & Software (/store/) Облачные сервисы (/cloud/) Курсы и вебинары (/courses/) Конференции и митапы (/events/) Видеозаписи (/video/) Биржа труда (/job/) Биржа фриланса (/freelance/) Форум (https://forum.infostart.ru/) Личный кабинет (/profile/index.php Цены на абонемент (/prices/) Техподдержка (/support/) Компания (/about/) |