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

28.08.19

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

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Длительные операции
.epf 6,45Kb
209
209 Скачать (1 SM) Купить за 1 850 руб.

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

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

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

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

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

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

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

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

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

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

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

Резюме

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

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

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

См. также

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

Синтакс-помощник БСП - cправочник по библиотеке стандартных подсистем. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП.

1800 руб.

21.11.2024    149    1    0    

2

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

В статье описан алгоритм для включения документа или справочника в систему БСП. Будет полезно программистам 1С, начинающим работать с БСП.

24.10.2024    1126    PROSTO-1C    0    

13

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

В материале описан универсальный механизм работы с добавленными элементами на общую форму «ФормаОтчета». Думаю, облегчит работу многим разработчикам.

08.10.2024    1006    PROSTO-1C    4    

12

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

В статье рассмотрим пошаговую инструкцию создания дополнительного отчета с фоновым формированием результата.

04.10.2024    1853    MadRave    11    

24

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

Пример отслеживания прогресса фонового выполнения дополнительной обработки с использованием программного интерфейса длительных операций БСП.

10.09.2024    1845    MadRave    1    

17

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

А что, если долгожданная реализация Паузы в 1С смутно напоминает старую, проверенную? А?!

06.09.2024    1265    n_mezentsev    10    

8

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

Добавим дополнительные свойства в новый документ средствами БСП

02.09.2024    4120    John_d    10    

52

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

Всё больше организаций выбирает для серверов под 1С операционные системы Linux. Одним из отличий систем Windows и Linux является отсутствие COM объектов, которые зачастую использовались для формирования печатных форм офисных документов (Word). Конечно, можно выполнять печать и на клиенте, но есть риск импортозамещения. В работе у меня случались проблемы с зависанием процесса Word, поэтому я не люблю его использовать.

29.07.2024    5377    PROSTO-1C    12    

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

Пометьте что ли, а то кому-нибудь как и мне придется переделывать.
user770928; Gaster; unichkin; ixijixi; Forest83; officeRebot; cleaner_it; yamarsel; PLAstic; Bassgood; wowik; Henistaromin; D_E_S131; korppinen; +14 Ответить
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Redokov 82 19.03.15 15:07 Сейчас в теме
Как насчет запуска длительных процессов из внешних обработок? Мне не удалось реализовать вызов экспортной процедуры. Если есть какой-то пример успешной реализации, поделитесь пожалуйста.
2. Bassgood 1449 20.03.15 00:53 Сейчас в теме
(1) Redokov, если Вы имеете ввиду вызов экспортной процедуры (длительной операции), расположенной в модуле внешней обработки, то без допиливания общих модулей БСП здесь не обойтись.
Если же Вы имеете ввиду вызов экспортной процедуры одного из модулей конфигурации из внешней обработки - то делается это так как описано в статье (приложенная к статье внешняя обработка тому пример).
3. Infactum 318 20.03.15 05:56 Сейчас в теме
(2) Вообще то вы не правы. Подсистема БСП "Дополнительные отчеты и обработки" содержит механизм для запуска длительных операций из модулей внешней обработки. Вот ссылка на ИТС. Без использование этих механизмов, к примеру, не примут к публикации внешние обработки для 1cfresh.com
mirco; ll13; Bassgood; +3 Ответить
4. Bassgood 1449 20.03.15 13:00 Сейчас в теме
(3) Infactum, Да, действительно в подсистеме БСП "Дополнительные отчеты и обработки" присутствует такой механизм, но в (1) речь шла, на сколько я понял, о возможности запуска длительной операции из модуля внешней обработки, представленной в виде внешнего файла, т.е. физически отделенной от базы (а не при помощи дополнительной обработки, содержащейся в базе в соответствующем справочнике).
Хотя по идее с помощью справочника дополнительных обработок можно организовать обращение и к внешним файлам обработок.
5. Redokov 82 03.04.15 00:47 Сейчас в теме
(4) Вы правы, речи идет о том, что мне нужно вызвать экспортную процедуру, располагающуюся во внешней обработке. Т.е., если я все правильно опнимаю, в этой самой обработке, придется продублировать функционал БСП по длительным операциям, но с учетом того, что располагаться эти операции будут не в конфигурации, а во внешней обработке.
Спасибо.
6. Novichok777 29 07.08.15 16:02 Сейчас в теме
(5) Redokov,
Интересно получилось у вас реализовать все во внешней обработке? Я натолкнулся на "стену" в виде обращения к процедуре обязательно общего модуля в ФоновыеЗадания.Выполнить("ОбщийМодуль.ПроцедураОбщегоМодуля", ПараметрыПроцедурыФоновогоЗадания, Ключ, Наименование). Туда то можно попасть, но вот как из нее вызвать экспортную процедуру внешней обработки не понимаю?
7. Bassgood 1449 10.08.15 10:26 Сейчас в теме
(6) Novichok777, в серверную экспортную процедуру "ОбщийМодуль.ПроцедураОбщегоМодуля" передаете в качестве параметра путь к файлу внешней обработки на сервере (или ссылку на элемент из справочника дополнительных обработок), а в самой процедуре уже работаете с объектом внешней обработки (ВнешниеОбработки.Создать(ИмяФайла)), т.е. тут особых проблем с этим нет, если есть соответствующую экспортная процедура в общем модуле, в которой уже можно реализовать любую логику.
12. fanast2 04.07.18 05:54 Сейчас в теме
(3) Ссылка ваша устарела видимо....
13. Infactum 318 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 1449 25.07.17 15:59 Сейчас в теме
(8) Должно работать, по идее этому механизму должно быть безразлично на вид клиента - он направляет выполнение длительного запроса на сервер в фоновый режим, ждет его завершения и выдает результат на форме.
Все что работает в толстом клиенте - отработает и на тонком, если Вы используете обычные формы, то конечно будет немного отличаться реализация процедур в модуле формы по работе с общими модулями механизма.
11. d4rkmesa 26.07.17 11:19 Сейчас в теме
(9)
(10)
Спасибо большое, попробую как-нибудь.
10. ImHunter 327 26.07.17 09:18 Сейчас в теме
(8) Будет работать. Проверено.
Bassgood; +1 Ответить
14. mangy 30 31.07.18 12:11 Сейчас в теме
Эта публикация устарела для текущей БСП. Сейчас используется РезультатВыполнения = ДлительныеОперации.ВыполнитьВФоне(

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