Что делать, когда обмены между разными базами данных портят вам жизнь…

10.09.21

Интеграция - Перенос данных 1C

Если при обмене между базами данных наблюдаются следующие симптомы: • Процедуры обмена занимают неприемлемо много времени. • Процессы обмена периодически вылетают «по ошибке» и их приходится запускать заново. • Поиск ошибок обмена превращается в ужасающий квест. То, скорее всего вы используете конфигурацию «Конвертация данных». А если при этом вам надоело получать сообщения службы поддержки о новых ошибках и вы бережете свои нервы, то данная статья написана прямо для вас. Чуть ниже я расскажу вам, как навсегда забыть проблемы, связанные со словом "обмен".

Если при обмене между базами данных наблюдаются следующие симптомы:

  • Процедуры обмена занимают неприемлемо много времени.
  • Процессы обмена периодически вылетают «по ошибке» и их приходится запускать заново.
  • Поиск ошибок обмена превращается в ужасающий квест.

То, скорее всего, вы используете конфигурацию «Конвертация данных». Неважно, какой редакции. Все отличие КД 2.0 от КД 3.0 в удобстве отладки и поиска ошибок (см. выше п. 3).

А если при этом, вам надоело получать сообщения службы поддержки, о новых ошибках, и вы бережете свои нервы, то данная статья написана прямо для вас.

Чуть ниже, я расскажу вам, как навсегда забыть проблемы связанные со словом ‘обмен’.

История проблемы и как пришло осознание того, что нарыв созрел и его пора вскрывать.

Две нетиповых базы данных (условно обзовем их БД1 и БД2):

  • В направлении БД1 -> БД2 передаются данные о нормативно справочной информации (НСИ).
    Все справочники создаются только на стороне БД1.
  • В направлении БД2 -> БД1 передается информация по кассовым документам. Объем передаваемых данных составляет около 400 000 документов в сутки или, в пиковые периоды, до 150 документов в секунду.
  • Объем файла обмена в пределах 0.7 – 2 Гб. Файл обмена транслируется через файловый ресурс.

С какими проблемами сталкивались:

  • Общее время обмена, за сутки, составляло порядка 15-20 часов. До 20% времени уходило на формирование и передачу файла обмена (на стороне источника).
  • Часть, из этого, уходила на запись файла обмена на дисковое пространство.
  • Еще большая часть, уходила на запросы к БД в цикле (таков принцип работы конфигурации «КД»)
  • Периодически, приходилось «резать» файл обмена на части, и проталкивать его в КИС руками.
  • В КД 2.0 (КД 3.0), пока не загрузился весь файл обмена, обмен не может считаться успешно состоявшимся.
  • Поэтому, если при загрузке данных, по 400 тысячам документов, хотя бы с одним документом произошел сбой – весь процесс обмена приходилось запускать заново.
  • Поиск ошибок обмена превращался в неблагодарный труд (вспомните добрым словом КД 2.0).

Как решали проблему и что это дало на выходе.

Если кратко, то выполнили следующее:

  • Отказались от использования конфигурации КД 2.0, в направлении БД2 – БД1 (трансляция кассовых документов).
  • Сбор данных отправки производится одним пакетом запросов к БД. Собранные данные трансформируются в строку JSON.
  • В базу-приемник данные передаются посредством HTTP-запроса.
  • Запись документов, в базу-приемник, производится без проведения и в несколько потоков.
  • Само проведение документов запускает специальный механизм отложенного проведения документов.

Более подробно, все технические аспекты – это тема отдельной публикации (планируется отдельно).

Результаты оптимизации обмена данными:

  • Все вышеперечисленное позволило организовать обмен данными фактически в режиме online. Частота обмена данными составляет 10 минут.
  • Среднее время транспорта 400 000 документов составляет не более 2ч. 30 минут.
  • Возможные ошибки передачи данных не прерывают транспортировку всего потока.
  • Простота поиска и локализации ошибок кода конвертации.

Но, это тоже еще не все! Есть еще и вишенка на тортике!

Мы решили не останавливаться на достигнутом и поставили себе целью сократить суточное время обменов до полутора часов! Возможно ли это?!

Мы помним, что в моменты пиковых нагрузок, количество одновременно проводимых документов доходит до 150 шт/сек. При данной интенсивности записей очень большую роль играет повышение параллельности работы системы, а именно – сокращению времени транзакционных блокировок.

В ходе замеров выяснилось, что при проведении кассовых документов, среднее время платформенной транзакции составляет 4.5 секунды на один документ.

При этом, подавляющее количество времени уходит на подготовку данных для новых наборов записей.

Вынеся, все данные процедуры, за пределы транзакции, мы добились сокращения времени платформенной транзакции до…… Внимание! – 0.003 сек!

И это еще не все! На момент написания статьи, мы работаем над тем, чтоб при пакетном проведении документов, все данные, необходимые для формирования наборов записей, получались одним пакетом запросов.

Этим самым мы ставим себе целью:

  • Разгрузить кластер серверов, снизив количество запросов с 400 000 до 288 запросов в сутки.
  • Снизить количество взаимоблокировок базы данных
  • И, в конечном итоге, снизим на порядок время проведения пакета документов.

В качестве резюме

Конфигурации «Конвертация данных 2.0» (КД 3.0) – отличные универсальные инструменты. Но, они крайне не готовы к работе с регулярными и большими объемами данных.

Сбор необходимых данных (одним запросом) для последующей online-передачи, может быть решением проблемы.

При пакетном проведении документов:

Получение данных (необходимых для формирования набора записей), производим одним запросом, с последующей передачей в документ-объект.

Данная методика позволяет повысить производительность системы в тысячу и более раз.

Обмен данными производительность APDEX оптимизация кластер серверов быстродействие конвертация загрузка

См. также

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    145080    843    297    

436

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.20.x), также подходят для релиза 11.5 (11.5.19.x).

35000 руб.

23.07.2020    55303    253    73    

206

SALE! 10%

Перенос данных 1C Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

55778 50200 руб.

04.08.2015    170058    353    281    

390

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 50200 руб.

15.04.2019    73829    196    154    

133

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    38000    106    69    

100

SALE! 10%

Перенос данных 1C Системный администратор Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Правила переноса данных из БП 3.0 в УТ 11 | из БП 3.0 в КА 2 | из БП 3.0 в ERP | Сэкономьте свое время - используйте готовое решение для перехода! | Постоянно работаем над развитием переноса данных | Обновляем на новые релизы 1С | Есть фильтр выгрузки по организациям | Переносятся начальные остатки на выбранную дату, документы за период времени и вся возможная справочная информация | Перенос сделан на технологии КД 2 (правила конвертации данных) Воспользовались более 122 предприятий! |

55778 50200 руб.

31.10.2014    238343    105    338    

308

Перенос данных 1C Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ ФОМС, ЕФС Платные (руб)

Обработки для быстрого перехода с конфигураций «КАМИН:Расчет заработной платы 3.0», «КАМИН:Зарплата для бизнеса 4.0» и «КАМИН:Зарплата 5.0» на конфигурацию «Зарплата и управление персоналом» версии 3.1.

12000 руб.

25.09.2016    82525    342    253    

292

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Платформа 1C v8.2 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Россия Платные (руб)

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 2, УНФ 1.6 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

16260 руб.

18.02.2016    188750    612    534    

534
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 1992 10.09.21 09:10 Сейчас в теме
технические аспекты – это тема отдельной публикации
Подписался! Звучит грандиозно!
DrAku1a; muskul; +2 Ответить
2. director04 3661 10.09.21 13:46 Сейчас в теме
(1) Более подробно, о компании и ее проектах, описано здесь https://habr.com/ru/company/magnit/blog/570992/
DrAku1a; ixijixi; +2 Ответить
3. MaxS 2976 17.09.21 08:53 Сейчас в теме
КД - это конфигурация, в которой прописывается таблица соответствия реквизитов. Всё остальное - это типовые механизмы конфигураций - БСП. Как выгружать и как проводить документы не зависит от технологии КД.
Собранные данные трансформируются в строку JSON.
В базу-приемник данные передаются посредством HTTP-запроса.
Запись документов, в базу-приемник, производится без проведения и в несколько потоков.
Само проведение документов запускает специальный механизм отложенного проведения документов.
Используя КД можно было сделать то же самое, первое действие выглядело бы так:
Собранные данные трансформируются в строку xml в формате как у КД2 или КД3.
далее так же.
Плюс такого варианта - разработчик правил в интерактивном режиме задаёт соответствия объектов и реквизитов. А обмены, распараллеливания и проведение берёт на себя Ваша универсальная система. Такой вариант проще поддерживать при зоопарке конфигураций.
Т.е. вместо БСП нужно сделать БКСП - библиотеку корпоративных стандартных подсистем. )
4. director04 3661 17.09.21 12:24 Сейчас в теме
(3) В теории все красиво.... Но, когда вы сталкиваетесь с теми объемами данных, которые я озвучил выше, то рулить начинает не теория, а практика.
Все что можно было "выжать" из КД 2.0 - было выжато давно. Да и не ради спора я опубликовал статью, а ради трансляции положительного опыта.
К сожалению, стандарты, диктуемые типовыми решениями от 1С, на практике не выдерживают испытания высоконагруженными системами.
Еще подчеркиваю, что КД - отличный и полезный механизм, но не для обменов данными по полмиллиона документов в сутки.
5. MaxS 2976 17.09.21 12:35 Сейчас в теме
(4) я тоже не ради спора, а... может быть 1С когда-нибудь будет выпускать те же БСП, ориентированные на максимальную скорость и масштабируемость для обработки данных, подобным вашим. Чтобы каждый раз не изобретать свой велосипед с положительным опытом )
В этом случае решение для массовых конфигураций будет совместимо с корпоративными версиями.
А пока 1С не заняло эту нишу, у Вас есть конкурентное преимущество. Можно тиражировать своё уникальное решение.
6. director04 3661 17.09.21 18:33 Сейчас в теме
(5) Представители 1С работают с нами вплотную, используя нашу площадку как испытательно-тестовый полигон для изучения работы 1С с большими базами данных.
Многие наши наработки (включая и взаимодействие Сервера приложений и Сервера БД) используются для будущих версий платформы 1С.
Но, следует понимать, что универсальные, типовые решения, вряд ли когда будут по скорости сопоставимы с кастомизированными подходами к решениям задач.
8. MaxS 2976 20.09.21 11:37 Сейчас в теме
(6)
Но, следует понимать, что универсальные, типовые решения, вряд ли когда будут по скорости сопоставимы с кастомизированными подходами к решениям задач.
Согласен.
Но как-то грустно наблюдать типовые правила обмена. От версии к версии добавляются костыли. В результате при обработке одного документа несколько раз в цикле обработки табличной части проверяется множество параметров-констант, как будто они могут измениться в другой строке.
Можно хотя бы постараться и типовой универсальный код делать производительнее и тогда процент организаций возрастёт, у которых типовое решение не тормозит. И не нужно будет кастомизировать для них решение.

С другой стороны универсальные решения дают работу множеству узких специалистов по кастомизации. )
director04; +1 Ответить
7. Labotamy 17.09.21 19:37 Сейчас в теме
Добро пожаловать в велоклу б)
9. gybson 21.09.21 09:38 Сейчас в теме
Если обе базы самописные, то что мешает вообще не конвертировать и лить данные через дефолтную сериализацию, как в РБД?

Обмен частями тоже вполне выполнимая задача, правда рискованная несколько. Добавить в имя файла номер сообщения, выгрузить изменения по нему, стереть регистрацию изменений. Но если файл потеряли, то ой. Частично решается более гарантированными средствами доставки, чем каталог, но риски остаются.
Оставьте свое сообщение