Универсальное регламентное задание для запуска внешних и встроенных обработок. Как настроить легко и быстро (8.х)

10.06.15

База данных - Инструменты администратора БД

Создаем и настраиваем регламентные задания на основании внешних и встроенных обработок просто и удобно.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Настройка регламентного выполнения внешних и встроенных обработок
.epf 12,97Kb
146
146 Скачать (1 SM) Купить за 1 850 руб.

Механизм, о котором пойдет речь ниже, позволяет гибко и оперативно создавать и настраивать регламентные задания без запуска конфигуратора. Это действенный инструмент, которого порой просто не хватает под рукой. 

Предлагаю рассмотреть один из способов реализации такого иснструмента собственными руками. Для тех же, у кого нет времени на болтовню автора статьи и/или же механизм нужен уже сейчас, прошу к скачиванию :)

И пока коллеги со второй категории скачивают обработку, мы ее напишем :)

Нам понадобится.

1. Создать регламентное задание с названием "ВыполнениеОбработки".

2. В качестве исполнительного метода регламентного задания указать метод ВыполнениеОбработки() из общего модуля МодульРегламентныхЗаданий (или любого другого общего модуля с такими же настройками свойств). Описать логику работы метода.

3. Написать обработку, которая будет программно создавать экземпляры регламентного задания с заданными параметрами.

Важно!

Любое регламентное задание имеет такое свойство как Параметры. Это Массив, назначение которого очевидно - хранение параметров, которые передаются на вход исполнительного метода регламентного задания. Более детально можно прочесть в синтаксис помощнике. Отметим только, что устанавливаются параметры регламентного задания только программноТакже следует помнить, что количество и состав параметров должны соответствовать параметрам метода регламентного задания.

Приступим.

Первым делом, создадим регламентное задание. Укажем исполнительный метод. Опишем его логику работы исходя из следующих условий

  • Регламентное задание должно уметь запускать как внешние, так и встроенные обработки.
  • Уметь передавать входящие параметры (первоначальные настройки) обработке на выполнение.
  • Логировать все свои действия в журнал регистрации
Первым параметром метода регламентного задания укажем ключ обработки. Он понадобится нам для идентификации обработки, которую нужно запустить на выполнение. В случае с внешней обработкой - это будет ее код из справочника "Внешние обработки", в случае со встроенной - имя из дерева метаданных. Второй параметр метода регламентного задания - произвольные настройки, которые хранятся в объекте с типом ХранилищеЗначения.
Ниже приведен листинг метода регламентного задания.

Процедура ВыполнениеОбработки(КодОбработки = Неопределено, СохраненныеНастройки = Неопределено) Экспорт

	ОбработкаРегламентногоЗадания = Неопределено;
	
	// Не указан код внешней (название встроенной) обработки 
	Если КодОбработки = Неопределено Тогда
		
		ЗаписьЖурналаРегистрации("Ошибка регламентированного выполнения обработки", УровеньЖурналаРегистрации.Предупреждение,,,
								 "Не правильно указан параметр '" + КодОбработки + "'");
		
		Возврат;		
		
	КонецЕсли;		
	
	ВнешняяОбработкаСсылка = Справочники.ВнешниеОбработки.НайтиПоКоду(КодОбработки);
	
	// Проверка, найдена ли внешняя обработка
	ВнешняяОбработкаПустая = Ложь;
	Если ВнешняяОбработкаСсылка = Неопределено Тогда
	    ВнешняяОбработкаПустая = Истина;		
	ИначеЕсли ВнешняяОбработкаСсылка.Пустая() Тогда		
		ВнешняяОбработкаПустая = Истина;	
	КонецЕсли; 
			
	// Возможно это встроенная обработка
	Если ВнешняяОбработкаПустая Тогда
	
		Для каждого ТекВстроеннаяОбработка Из Метаданные.Обработки Цикл
		
			Если СокрЛП(ТекВстроеннаяОбработка.Имя) = СокрЛП(КодОбработки) Тогда
			
				ОбработкаРегламентногоЗадания = Обработки[КодОбработки].Создать();
				
				// Нашли встроенную обработку. Выйти из цикла 
				Прервать;										
				
			КонецЕсли; 	
		
		КонецЦикла;
		
		// Не удалось найти встроенную обработку
		Если ОбработкаРегламентногоЗадания = Неопределено Тогда
		
			ЗаписьЖурналаРегистрации("Ошибка регламентированного выполнения обработки", УровеньЖурналаРегистрации.Предупреждение,,,
									 "Обработка '" + КодОбработки + "' не найдена");
		
			Возврат;	
		
		КонецЕсли; 
				
	// Это внешняя обработка			
	Иначе
		
		ДвоичныеДанные = ВнешняяОбработкаСсылка.ХранилищеВнешнейОбработки.Получить();
		
		// внешнюю обработку невозможно преобразовать в двоичные данные 
		Если ДвоичныеДанные = Неопределено Тогда
			
			ЗаписьЖурналаРегистрации("Ошибка регламентированного выполнения обработки", УровеньЖурналаРегистрации.Предупреждение,,,
									 "Внешняя обработка '"+КодОбработки+"' не имеет двоичных данных");
			
			Возврат;
			
		КонецЕсли;
		
		Попытка
			
			АдресВоВременномХранилище = ПоместитьВоВременноеХранилище(ДвоичныеДанные);
			ИмяОбработки = ВнешниеОбработки.Подключить(АдресВоВременномХранилище, , Ложь);
			
			Если ВнешняяОбработкаСсылка.ВидОбработки = Перечисления.ВидыДополнительныхВнешнихОбработок.Обработка Тогда
				ОбработкаРегламентногоЗадания = ВнешниеОбработки.Создать(ИмяОбработки);				
			Иначе                                                                      				
				ОбработкаРегламентногоЗадания = ВнешниеОтчеты.Создать(ИмяОбработки);   				
			КонецЕсли;
			
		Исключение 			
			
			ЗаписьЖурналаРегистрации("Ошибка регламентированного выполнения обработки", УровеньЖурналаРегистрации.Предупреждение,,,
									 "Не удалось подключить внешнюю обработку '"+ВнешняяОбработкаСсылка+"'");
									 
			Возврат;
			
		КонецПопытки;
			
	КонецЕсли;
	
	Попытка
		
		Если СохраненныеНастройки = Неопределено Тогда		
			ОбработкаРегламентногоЗадания.ВыполнитьЗадание();			
		ИначеЕсли ТипЗнч(СохраненныеНастройки) <> Тип("ХранилищеЗначения") Тогда			
			ОбработкаРегламентногоЗадания.ВыполнитьЗадание();                   			
		ИначеЕсли ТипЗнч(СохраненныеНастройки) = Тип("ХранилищеЗначения") Тогда 
			ОбработкаРегламентногоЗадания.ВыполнитьЗадание(СохраненныеНастройки);			
		КонецЕсли; 
				
	Исключение
		
		ЗаписьЖурналаРегистрации("Ошибка регламентированного выполнения обработки", УровеньЖурналаРегистрации.Предупреждение,,,
								 "Обработка '" + ОбработкаРегламентногоЗадания + "' должна иметь в модуле экспортную процедуру 'ВыполнитьЗадание()'");
		
	КонецПопытки;
	
КонецПроцедуры

Теперь опишем обработку, которая будет создавать экземпляры выше описанного регламентного задания.

Как все работает изнутри, лучше всего расскажет программный код исполнительной процедуры (обработчик нажатия на кнопку "Запустить регламентное задание").

Процедура КнопкаВыполнитьНажатие(Кнопка)
	// Проверим все ли реквизиты на форме заполнены корректно
	Если НЕ ОбязательныеРеквизитыЗаполнены() Тогда
		
		Возврат;
		
	КонецЕсли;
	
    ОбъектЗадания = РегламентныеЗадания.СоздатьРегламентноеЗадание("ВыполнениеОбработки");
	ОбъектЗадания.Наименование 	= Наименование;
	ОбъектЗадания.Ключ 		= Ключ;
	ОбъектЗадания.Использование	= Использование;
	
	ОбъектЗадания.ИмяПользователя = ИмяПользователя;
	
	ОбъектЗадания.КоличествоПовторовПриАварийномЗавершении 	= КоличествоПовторовПриАварийномЗавершении;
	ОбъектЗадания.ИнтервалПовтораПриАварийномЗавершении 	= ИнтервалПовтораПриАварийномЗавершении;
	
	ЗначениеСохраненнойНастройки = ПолучитьЗначениеСохраненнойНастройки();
	
	Параметры = Новый Массив();
	Параметры.Добавить(Ключ);
	
	Если ЗначениеСохраненнойНастройки <> Неопределено Тогда
	
		Параметры.Добавить(ЗначениеСохраненнойНастройки);	
	
	КонецЕсли; 
	
	ОбъектЗадания.Параметры = Параметры;
			
	Попытка
		
		ОбъектЗадания.Записать();
						
	Исключение
		
		ВызватьИсключение "Произошла ошибка при запуске регламентного задания.
		|Подробное описание ошибки: " + ОписаниеОшибки();
		
	КонецПопытки;
	
КонецПроцедуры

После всего проделанного, любая обработка может быть запущена регламентным заданием. Для этого ей достаточно в модуле объекта содержать экспортную процедуру ВыполнитьЗадание().

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

Дополнительную информацию по теме читайте в статьях //infostart.ru/public/183110/ и //infostart.ru/public/191266/ . Авторам спасибо за идеи, мысли и изложенный материал.

Универсальное регламентное задание обработка

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    13162    100    46    

104

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 18.09.2024, версия 1.2

18000 руб.

06.12.2023    10147    47    5    

78

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

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

4800 3840 руб.

14.01.2013    190741    1151    0    

918

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

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

15000 руб.

10.11.2023    11471    40    27    

66

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    33671    109    152    

75

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

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

3600 руб.

06.02.2017    32526    145    18    

51

Архивирование (backup) Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    73601    629    45    

88

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

Многие сталкиваются с проблемой когда изображения, находящиеся в базе разные по объему и размерам. Менеджеры могут добавить файлы в очень высоком разрешении, объемом свыше 20 Мегабайт. База данных становится слишком большой, выгрузка на сайт идёт медленно и требуется много место на хостинге. Как сжать картинки и уменьшить размер базы 1С? Это можно сделать с помощью данной обработки. Существует возможность выбрать различные варианты для того чтобы уменьшить картинки: в разы, в процентах от первоначального объема, а также сделать картинки одинаковой ширины. В результате размер базы 1С значительно сократится (в зависимости от количества и размера картинок), а изображения станут небольшого объема, равными по ширине, почти без потери качества. Работает на управляемых формах для УТ 11, КА, ERP.

3000 руб.

21.07.2022    10120    9    4    

17
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ProX 74 16.06.15 11:24 Сейчас в теме
Если вам помогла обработка, оставьте комментарий :)
2. dmitrichenko.ivan 6 17.06.15 17:43 Сейчас в теме
В БСП же реализован запуск внешних обработок по расписанию?
3. ProX 74 18.06.15 14:22 Сейчас в теме
Реализовано. На управляемых формах и без возможности подключения встроенных обработок.
Для переноса механизма регламентированного запуска внешних обработок из БСП в любую другую конфигурацию придется попотеть, и доработать гораздо больше объектов нежели того требует механизм, описанный в статье. Выбор за Вами :)
4. mip128 29.06.15 15:22 Сейчас в теме
А ты можешь написать типы значений реквизитов обработки?
5. ProX 74 30.06.15 11:19 Сейчас в теме
Наименование: Поле ввода (Строка),
Ключ: Поле ввода (Строка),
Имя пользователя: Поле ввода (Строка) (Список пользователей заполняется программно в модуле формы)
Сохраненная настройка: Поле выбора (Строка) (Список настроек заполняется программно в модуле формы)
Внешняя обработка: Поле ввода (СправочникСсылка.ВнешниеОбработки)
Обработка из конфигуратора: Поле выбора (Строка). Список обработок заполняется программно по метаданным.
Использование: Булево
Расписание регламентного задания: гиперссылка открывающая форму диалога расписания регламентного задания
6. mip128 06.07.15 17:53 Сейчас в теме
Ну без скачивания обработки все равно сложно самостоятельно создать)
7. mip128 05.02.16 10:06 Сейчас в теме
У тебя еще в
ВнешниеОбработки.Создать(ИмяОбработки)
надо бы указывать второй параметр БезопасныйРежим, это довольно важно
8. arakelyan 396 15.06.18 11:31 Сейчас в теме
Полезные материалы, спасибо.
9. buketov_av 12.03.19 13:09 Сейчас в теме
Дико извиняюсь, но у меня не открывается форма. Написано ведь 8.х
10. ShopKanc 27.11.20 10:35 Сейчас в теме
11. shalupov61 09.02.22 07:58 Сейчас в теме
В скаченной обработке форма "ДиалогРегламентногоЗадания" не соответствует скриншоту публикации - на форме нет полей для выбора внешней обработки или обработки из конфигуратора
12. shalupov61 09.02.22 11:49 Сейчас в теме
Пардон, ошибся - не ту обработку запускал. Вроде пока всё нормально (если не считать, что в модуле формы пришлось заменить "Пользователи" на "Пользователи1":

Пользователи1 = ПользователиИнформационнойБазы.ПолучитьПользователей();

Для Каждого Пользователь из Пользователи1 Цикл
ЭлементыФормы.ИмяПользователя.СписокВыбора.Добавить(Пользователь.Имя, Пользователь.ПолноеИмя);
КонецЦикла;
13. shalupov61 09.02.22 13:10 Сейчас в теме
Внешняя обработка, запуск которой настроил, не выполняется, в консоли в журнале ошибка предупреждения безопасности, т.е. при запуске спрашивает "Разрешить выполнять файл". При настройке регламентного задания необходимо указывать пользователя, у которого отключен флаг "Защита от опасных действий"
14. ivlog 24.03.22 09:20 Сейчас в теме
Скачал и установил обработку. Фоновое задание запускается и завершается успешно, но моя обработка, не запускается. Подскажите, что я мог упустить, куда посмотреть. Спасибо.
Оставьте свое сообщение