Как вы могли уже догадаться, речь пойдет об ошибке, указанной в заголовке публикации. Суть проблемы в следующем: после изменения метаданных в расширении, используемом в РИБе (был изменен тип одного из реквизитов на составной), при попытке синхронизации в узле получили следующую ошибку: "В процессе обновления информационной базы произошла некритичная ошибка: Установка расширений конфигурации, модифицирующих структуры данных, в фоновом задании запрещена".
Поиск по ошибке результатов не дал, что и послужило поводом для создания данной публикации.
Поиск вариантов решения
Обращаясь к предыдущему опыту работы на платформах 8.3.13.1513 и 8.3.13.1690 первым делом были предприняты попытки выполнить синхронизацию в узле с использованием других версий платформы, но это не принесло результатов, как и попытка использовать параметр запуска /AllowExecuteScheduledJobs –Off. Следующим шагом оказалась попытка выполнения синхронизации через Выполнение сценария по мотивам публикации РИБ и расширения
После выполнения сценария появилось сообщение о том, что объект был изменён и синхронизация не выполнена! Но если мы посмотрим события получения данных, то увидим сообщение с ошибкой "Из главного узла распределенной информационной базы получены изменения расширений конфигурации. Необходимо выполнить перезапуск приложения". Нам остается только следовать тексту сообщения, т.е. перезапустить приложение, выполнить синхронизацию в штатном режиме и получить непосредственно данные.
Размышления на тему происходящего.
Автор поста РИБ и расширения не высказывал вероятных причин такого поведения, но исходя из текстов ошибок и исследования модулей отвечающих за синхронизацию, делаем вывод: при выполнении синхронизации штатными методами выполняется она с помощью фоновых заданий, которым в моём случае запрещено вносить изменения в метаданные конфигурации, а запуск сценариев с формы выполняется без использования фоновых заданий.