Использование общих модулей "Длительные операции" из состава БСП или асинхронное выполнение серверных процедур без блокировки пользовательского интерфейса

28.08.19

Разработка - БСП (Библиотека стандартных подсистем)

В статье кратко описан способ использования процедур общих модулей "Длительные операции" из состава библиотеки стандартных подсистем (БСП). Статья будет полезна программистам и администраторам, работающих с объемными клиент-серверными базами, конфигурации которых включают в себя БСП. К длительным операциям можно отнести, например, такие процедуры как групповое проведение документов, формирование объемистых отчетов, работа с внешними источниками данных.

Скачать файлы

Наименование Файл Версия Размер
Длительные операции
.epf 6,45Kb
206
.epf 6,45Kb 206 Скачать

Теоретическая часть

Использование общих модулей "Длительные операции" позволяет перенести всю тяжесть исполнения ресурсоемких процедур на сторону сервера, не мешая при этом работе клиентского приложения, инициировавшего этот процесс, т.е. не мешая дальнейшей работе пользователя в приложении. Описанная возможность реализуется в модулях БСП за счет исполнения "тяжелых" процедур на сервере в фоновом режиме (запуску фоновых заданий под каждую процедуру).

Ниже приведены процедуры, позволяющие реализовать в любой форме возможность выполнения необходимой вам длительной операции в фоновом режиме. Для этого в форме обязательно должны содержаться два реквизита "АдресХранилища" (типа строка) и "ИдентификаторЗадания" (типа уникального идентификатора), в модуле формы должна быть объявлена клиентская переменная "ПараметрыОбработчикаОжидания". Помимо этого экспортная процедура длительной операции должна содержать в себе два параметра "СтруктураПараметров" (типа структуры) и "АдресХранилища" (типа строка), результат исполнения должен быть помещен во временное хранилище, а адрес в нем должен быть присвоен параметру "АдресХранилища".

Практическая часть

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

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

&НаКлиенте
Процедура ВыполнитьПроцедуруФоново(Команда)
	
  ОтключитьОбработчикОжидания("Подключаемый_ПроверитьВыполнениеЗадания");
	
  РезультатВыполнения = ВыполнитьФоновоеЗаданиеНаСервере();
	
  Если РезультатВыполнения.ЗаданиеВыполнено Тогда	
      РезультатВыполнения = ПолучитьИзВременногоХранилища(АдресХранилища);
  Иначе
      ДлительныеОперацииКлиент.ИнициализироватьПараметрыОбработчикаОжидания(ПараметрыОбработчикаОжидания);
      ПодключитьОбработчикОжидания("Подключаемый_ПроверитьВыполнениеЗадания", 1, Истина);	
  КонецЕсли;
	
КонецПроцедуры

Собственно сама серверная процедура, которая запускает необходимую нам длительную операцию, вызов которой будет произведен из "ИмяМодуля.ИмяЭкспортнойПроцедуры". Также в этой процедуре заполняется структура параметров, необходимых для исполнения длительной операции, и запоминается идентификатор фонового задания, под которым выполняется длительная операция.    

&НаСервере
Функция ВыполнитьФоновоеЗаданиеНаСервере()
			
  ДлительныеОперации.ОтменитьВыполнениеЗадания(ИдентификаторЗадания);	
  ИдентификаторЗадания = Неопределено;
	
  СтруктураПараметров = Новый Структура;	
	
  Если ОбщегоНазначения.ИнформационнаяБазаФайловая() Тогда
		
     АдресХранилища = ПоместитьВоВременноеХранилище(Неопределено, УникальныйИдентификатор);
     // здесь должен быть вызов нашей процедуры
     РезультатВыполнения = Новый Структура("ЗаданиеВыполнено", Истина);
		
  Иначе
		
     РезультатВыполнения  = ДлительныеОперации.ЗапуститьВыполнениеВФоне(УникальныйИдентификатор, 
     "ИмяМодуля.ИмяЭкспортнойПроцедуры", 
     СтруктураПараметров, 
     "Наименование фонового задания");	
		
     ИдентификаторЗадания = РезультатВыполнения.ИдентификаторЗадания;
     АдресХранилища       = РезультатВыполнения.АдресХранилища;	
		
  КонецЕсли;
		
  Возврат РезультатВыполнения;
	
КонецФункции

Процедура обработчика ожидания мониторит выполнение запущенного нами фонового задания, в случае успеха - результат выполнения длительной операции извлекается из временного хранилища по адресу "АдресХранилища", в противном случае обработчик ожидания подключается заново для следующей очередной проверки. 

&НаКлиенте
Процедура Подключаемый_ПроверитьВыполнениеЗадания()
	
  Попытка
     Если ЗаданиеВыполнено(ИдентификаторЗадания) Тогда 
        РезультатВыполнения = ПолучитьИзВременногоХранилища(АдресХранилища);
     Иначе
	ДлительныеОперацииКлиент.ОбновитьПараметрыОбработчикаОжидания(ПараметрыОбработчикаОжидания);
	ПодключитьОбработчикОжидания("Подключаемый_ПроверитьВыполнениеЗадания", 
	ПараметрыОбработчикаОжидания.ТекущийИнтервал, Истина);
    КонецЕсли;
  Исключение		
     ВызватьИсключение;
  КонецПопытки;
	
КонецПроцедуры
&НаСервереБезКонтекста
Функция ЗаданиеВыполнено(ИдентификаторЗадания)	
     Возврат ДлительныеОперации.ЗаданиеВыполнено(ИдентификаторЗадания);	
КонецФункции

Резюме

Использование процедур общих модулей "Длительные операции", входящих в состав БСП, позволяет довольно удобным и быстрым способом осуществить в конфигурации выполнение необходимых длительных ресурсоемких операций, инициируемых пользователями системы, на стороне сервера в фоновом режиме, что делает работу пользователей в приложении более комфортной и производительной (не блокируется весь пользовательский интерфейс на время выполнения длительной операции и возможность параллельного запуска нескольких длительных операций). 

P.S. Ниже расположена демонстрационная обработка, в модуль формы которой помещены все вышеописанные процедуры.
 

длительные операции фоновые задания БСП асинхронное

См. также

Создать на основании - своя кнопка (БСП). Проблема двух подменю Создать на основании

БСП (Библиотека стандартных подсистем) Адаптация типовых решений Платформа 1С v8.3 1С:ERP Управление предприятием 2 Бесплатно (free)

Понадобилось в подменю "Создать на основании" добавить свою команду, которая открывает обработку. В процессе доработок появилась проблема двух подменю "Создать на основании". В статье о том, как решились проблемы.

01.03.2024    1282    dimanich70    6    

13

Заполнение поля адреса в своей обработке [БСП]

Механизмы платформы 1С БСП (Библиотека стандартных подсистем) Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Небольшая шпаргалка по функциям БСП касательно адреса. Так скажем, еще один способ помимо https://infostart.ru/1c/articles/1060970/

12.02.2024    687    FilippovRI    0    

15

Расширяем возможности дополнительных обработок и настраиваем их отладку

БСП (Библиотека стандартных подсистем) Механизмы типовых конфигураций Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Уже не одна веб-страница исписана знаниями о дополнительных обработках, как создать, как подключить. Есть масса вариантов, как их можно отладить. Я разобрался в кишках работы библиотеки и покажу, как можно расширить возможности дополнительных отчетов, а также покажу удобный способ отладки.

07.02.2024    2351    YA_418728146    11    

40

1С:БСП Дополнительные реквизиты и сведения

БСП (Библиотека стандартных подсистем) Платформа 1С v8.3 Бесплатно (free)

В этой статье расскажем об архитектуре, использовании и особенностях реализации подсистемы «Свойства» из инструментария разработчика «1С:Библиотека стандартных подсистем» (1С: БСП).

19.01.2024    5166    PROSTO-1C    5    

45

Бесплатный митап 9 февраля «Библиотеки и фреймворки на 1С и всё, что с этим связано»

БСП (Библиотека стандартных подсистем) Мероприятия Бесплатно (free)

Митап посвящен вопросам создания, использования и поддержке переиспользуемого кода при разработке решений на платформе 1С:Предприятие 8.

15.01.2024    3799    0    Infostart    0    

20

Шаблоны новых объектов 1С для 1С:Бухгалтерии предприятия

Инструментарий разработчика БСП (Библиотека стандартных подсистем) Механизмы типовых конфигураций Платформа 1С v8.3 1С:Бухгалтерия 3.0 Бесплатно (free)

Используются для создания новых объектов в конфигурации, чтобы не забыть, что нужно сделать. Сделано на примере 1С:Бухгалтерия предприятия, в других конфигурациях могут быть другие, а могут быть и похожие объекты.

28.12.2023    4832    mrXoxot    11    

99
Отзывы
14. mangy 30 31.07.18 12:11 Сейчас в теме
Эта публикация устарела для текущей БСП. Сейчас используется РезультатВыполнения = ДлительныеОперации.ВыполнитьВФоне(

Пометьте что ли, а то кому-нибудь как и мне придется переделывать.
unichkin; ixijixi; Forest83; officeRebot; cleaner_it; yamarsel; PLAstic; Bassgood; wowik; Henistaromin; D_E_S131; korppinen; +12 Ответить
Остальные комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Redokov 81 19.03.15 15:07 Сейчас в теме
Как насчет запуска длительных процессов из внешних обработок? Мне не удалось реализовать вызов экспортной процедуры. Если есть какой-то пример успешной реализации, поделитесь пожалуйста.
2. Bassgood 1425 20.03.15 00:53 Сейчас в теме
(1) Redokov, если Вы имеете ввиду вызов экспортной процедуры (длительной операции), расположенной в модуле внешней обработки, то без допиливания общих модулей БСП здесь не обойтись.
Если же Вы имеете ввиду вызов экспортной процедуры одного из модулей конфигурации из внешней обработки - то делается это так как описано в статье (приложенная к статье внешняя обработка тому пример).
3. Infactum 315 20.03.15 05:56 Сейчас в теме
(2) Вообще то вы не правы. Подсистема БСП "Дополнительные отчеты и обработки" содержит механизм для запуска длительных операций из модулей внешней обработки. Вот ссылка на ИТС. Без использование этих механизмов, к примеру, не примут к публикации внешние обработки для 1cfresh.com
mirco; ll13; Bassgood; +3 Ответить
4. Bassgood 1425 20.03.15 13:00 Сейчас в теме
(3) Infactum, Да, действительно в подсистеме БСП "Дополнительные отчеты и обработки" присутствует такой механизм, но в (1) речь шла, на сколько я понял, о возможности запуска длительной операции из модуля внешней обработки, представленной в виде внешнего файла, т.е. физически отделенной от базы (а не при помощи дополнительной обработки, содержащейся в базе в соответствующем справочнике).
Хотя по идее с помощью справочника дополнительных обработок можно организовать обращение и к внешним файлам обработок.
5. Redokov 81 03.04.15 00:47 Сейчас в теме
(4) Вы правы, речи идет о том, что мне нужно вызвать экспортную процедуру, располагающуюся во внешней обработке. Т.е., если я все правильно опнимаю, в этой самой обработке, придется продублировать функционал БСП по длительным операциям, но с учетом того, что располагаться эти операции будут не в конфигурации, а во внешней обработке.
Спасибо.
6. Novichok777 25 07.08.15 16:02 Сейчас в теме
(5) Redokov,
Интересно получилось у вас реализовать все во внешней обработке? Я натолкнулся на "стену" в виде обращения к процедуре обязательно общего модуля в ФоновыеЗадания.Выполнить("ОбщийМодуль.ПроцедураОбщегоМодуля", ПараметрыПроцедурыФоновогоЗадания, Ключ, Наименование). Туда то можно попасть, но вот как из нее вызвать экспортную процедуру внешней обработки не понимаю?
7. Bassgood 1425 10.08.15 10:26 Сейчас в теме
(6) Novichok777, в серверную экспортную процедуру "ОбщийМодуль.ПроцедураОбщегоМодуля" передаете в качестве параметра путь к файлу внешней обработки на сервере (или ссылку на элемент из справочника дополнительных обработок), а в самой процедуре уже работаете с объектом внешней обработки (ВнешниеОбработки.Создать(ИмяФайла)), т.е. тут особых проблем с этим нет, если есть соответствующую экспортная процедура в общем модуле, в которой уже можно реализовать любую логику.
12. fanast2 04.07.18 05:54 Сейчас в теме
(3) Ссылка ваша устарела видимо....
13. Infactum 315 04.07.18 09:46 Сейчас в теме
(12) Это же ИТС. Там все меняется совершенно хаотично. Сейчас несколько трудно сказать, куда вела ссылка 3 года назад, но видимо сюда:

Главная - Разработка и администрирование - Библиотека стандартных подсистем X.X.X. Документация - Глава X. Настройка и использование подсистем при разработке конфигурации - X.XX. Дополнительные отчеты и обработки - Использование при разработке конфигурации - Фоновое выполнение длительных операций

Тык
uno-c; nekit_rdx; user843739; +3 Ответить
8. d4rkmesa 25.07.17 15:41 Сейчас в теме
В конфигурации со свойствами Основной режим запуска - Обычное приложение и галочкой "Использовать управляемые формы в обычном приложении"(как в УПП), наверное, не будет работать, если не запускать через тонкий клиент?
9. Bassgood 1425 25.07.17 15:59 Сейчас в теме
(8) Должно работать, по идее этому механизму должно быть безразлично на вид клиента - он направляет выполнение длительного запроса на сервер в фоновый режим, ждет его завершения и выдает результат на форме.
Все что работает в толстом клиенте - отработает и на тонком, если Вы используете обычные формы, то конечно будет немного отличаться реализация процедур в модуле формы по работе с общими модулями механизма.
11. d4rkmesa 26.07.17 11:19 Сейчас в теме
(9)
(10)
Спасибо большое, попробую как-нибудь.
10. ImHunter 312 26.07.17 09:18 Сейчас в теме
(8) Будет работать. Проверено.
Bassgood; +1 Ответить
14. mangy 30 31.07.18 12:11 Сейчас в теме
Эта публикация устарела для текущей БСП. Сейчас используется РезультатВыполнения = ДлительныеОперации.ВыполнитьВФоне(

Пометьте что ли, а то кому-нибудь как и мне придется переделывать.
unichkin; ixijixi; Forest83; officeRebot; cleaner_it; yamarsel; PLAstic; Bassgood; wowik; Henistaromin; D_E_S131; korppinen; +12 Ответить
15. pvl_mksv 20 06.06.19 13:12 Сейчас в теме
(14)А как такое выполнение отлаживается?
16. user1194102 07.02.20 11:23 Сейчас в теме
(14)
Эта публикация устарела для текущей БСП. Сейчас используется РезультатВыполнения = ДлительныеОперации.ВыполнитьВФоне(
из внешней обработки она запускается или нет?
Оставьте свое сообщение