gifts2017

Восстановление последовательностей интервалами

Опубликовал Юрий Хрипачёв (hrip) в раздел Администрирование - Сервисные утилиты

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

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

Функция модуля обработки «ВыполнитьВосстановлениеПоследовательностей» разработана так, чтобы её можно было перенести в общий модуль и использовать на сервере в регламентных заданиях. Пример восстановления последовательностей с помощью регламентных заданий уже был описан в статье http://infostart.ru/public/20592/

Ну и по времени восстановление последовательностей небольшими периодами с помощью данной обработки оказалось быстрее, чем восстановление стандартной обработкой.

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

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

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

Наименование Файл Версия Размер
Восстановление последовательностей 390
.epf 19,94Kb
22.08.14
390
.epf 19,94Kb Скачать

См. также

Подписаться Добавить вознаграждение

Комментарии

1. hanio (hanio) 25.10.11 10:54
Вот три недели назад бы ты обработину выложил, а так я уже свою аналогичную сделал, впрочем это не отменяет мой плюс ;)
2. hanio (hanio) 25.10.11 11:29
Кстати молодец отлично все учел и паузы и транзакцию, маленькое уточнение - паузу в своей обработке я повесил на расписание по одной той причине что в течении суток у меня есть пики работы операторов и ограничиться только одной паузой я не смог - как пример с 16 часов до 21 часа пауза составляет 15 секунд (проведение реализаций и прочих документов максимально в это время), с 21 часа по 3 ночи пауза 5 секунд (проверено что достаточно), с 3 ночи до 7 утра - паузы нет вообще, остальное время пауза 2 секунды. Все выверено экспериментально. Если сможешь допиши свою обработку и я тогда даже свою не буду выкладывать, потому что у тебя очень грамотно. И вопрос вдогонку - у меня почему то встречалось в последовательности реализации помеченные на удаление, у тебя не встречалось? Мне просто не понятно - движения нет, есть конечно документ-основание - проведенный заказ, но на этом у меня останавливалась граница последовательности.
3. hanio (hanio) 25.10.11 11:32
Да и вставь Обработку прерывания - это уже норма в программировании ;)
4. Юрий Хрипачёв (hrip) 25.10.11 11:46
(3) hanio, ОбработкаПрерыванияПользователя() там стоит аж в нескольких местах :-)
5. Юрий Хрипачёв (hrip) 25.10.11 11:56
(2) hanio, У меня есть мысль сделать реквизит время запуска т.е. нажал кнопу и пошел, а обработка сама стартует в обозначенное время. А вообще планирую функцию(ВыполнитьВосстановлениеПоследовательностей), которая восстанавливает последовательность поместить в общий модуль и там уже запускать по расписанию регламентным заданием. Различные варианты запуска обработки можно сохранить в настройках
Про помеченные на удаление документы в последовательностях ничего не могу сказать, я же выборку документов из последовательностей не делаю - использую Последовательности.Восстановить()
6. Александр Капустин (kapustinag) 25.10.11 11:59
(2) hanio,
hanio пишет:

... И вопрос вдогонку - у меня почему то встречалось в последовательности реализации помеченные на удаление, у тебя не встречалось? Мне просто не понятно - движения нет, есть конечно документ-основание - проведенный заказ, но на этом у меня останавливалась граница последовательности.


Это, возможно, известный баг в УПП, до сих пор не устраненный (по крайней мере, в 1.2.39.1 он все еще наблюдается):
- если пометить на удаление проведенный документ (т.е. не отменять проведение, а сразу пометить на удаление), то в некоторых ситуациях движения остаются.
Кроме того, если конфигурация с исправлениями, то могут быть и другие причины.
7. hanio (hanio) 25.10.11 12:31
в регламентах так то можно но тогда надо делать дополнительные телодвижения а так было бы удобно прямо тут настроить паузы. И кстати я немного по другому реализовал - я запросом вытягивал те документы которые есть в последовательности и начинал их перепроводить, здесь понимаешь какой плюс есть - четко можно видеть весь список документов последовательности и ручками в случае некорректной ситуации ставить на следующий документ ГП.
(6) А насчет бага что помеченный на удаление лезет в последовательность то у меня УТ 10.3.12.3 а платформа 1С:Предприятие 8.2 (8.2.11.236). В ней наблюдается такое? и еще если бы такой косяк имел место то это бы всплыло ведь в регистрах раз движения не ушли...
8. Юрий Хрипачёв (hrip) 25.10.11 13:40
(7) hanio, Последовательности.Восстановить() блокирует для пользователей возможность проведения документов которые входят в последовательность, поэтому некорректной ситуации не будет (ну а для уверенности можно дату запрета поставить :-)), может ошибкой завершиться только попытка запуска восстановления нового интервала, поэтому и нужен перезапуск, и ручками не надо ничего править.
А насчет регламентных заданий. Раньше мне приходилось запускать постоянно ручками различные обработки, после того как сделал вместо них регламентные задания я уже и забыл что такие обработки существуют.
А про баг с помеченными на удаление не знал - надо будет проверить.
9. Юрий Хрипачёв (hrip) 25.10.11 13:41
(7) hanio, Будет время попробую расписание сделать
10. hanio (hanio) 25.10.11 14:45
именно дата запрета редактирования и отследит за тем что не получится у пользователей влезть в последовательность. У меня была задача с января протащить границу последовательности, а как протащил там и твой вариант будет нормально работать.
11. Евгений Юпринский (Evgeny2009) 26.10.11 14:52
Супер!!! Просто находка!! Можно мне на sotikom@bk.ru отправить а то плюсиков не хватает (. За реализацию идеи "+"!!
12. adeich adeich (adeich) 26.10.11 17:05
Во, блин........... Сидел вчера сам ваял, так была нужна........... Но однозначно "ПЛЮС"
13. Юрий Хрипачёв (hrip) 27.10.11 08:21
Добавил реквизит время запуска, теперь можно нажать кнопку и автоматическое восстановление запустится в указанное время.
14. denis leonov (curys) 27.10.11 11:40
Огромное спасибо за грамотную разработку и грамотный код!
15. Юрий Хрипачёв (hrip) 27.10.11 11:54
16. Алексей Новоселов (a-novoselov) 27.10.11 15:37
(5) А зачем переносить процедуру в общий модуль? что мешает добавить в общий модуль процедуру для фонового задания с единственной строчкой:
ВнешниеОбработки.Создать("С:\Путь до моей обработки\ВосстановлениеПоследовательности.epf").ВыполнитьВосстановлениеПоследовательностей();
17. Юрий Хрипачёв (hrip) 27.10.11 16:05
(16) a-novoselov, можно и так сделать. Программирование тем и хорошо что можно одну и ту же задачу выполнить разными способами. Главное чтобы в функции ВыполнитьВосстановлениеПоследовательностей() не было вызовов клиентских процедур (например Сообщить(), Состояние()).
А по моему мнению если изменять конфигурацию и создавать новое регламентное задание, то всё равно в каком то модуле придется создать процедуру которая запускает это задание, там же например можно разместить и ВыполнитьВосстановлениеПоследовательностей(), а не полагаться на наличие обработки где то на диске (ведь есть вариант что база может быть перенесена в другое место или на другой сервер, а про обработку можно элементарно забыть, ну или например удалит ее кто нибудь случайно).
19. Анатолий Варягин (vartos) 16.11.11 09:10
очень полезная обработка, спасибо автору. Только вопрос - как она отработает, если в базе ведется учет в разрезе нескольких организаций?
20. Юрий Хрипачёв (hrip) 16.11.11 09:28
(19) vartos, Восстанавливает последовательности по всем организациям сразу. Мысль была сделать отбор по организациям, но потребности у меня такой небыло. Попробую сделать.
21. ира павлюк (irapronira) 07.02.12 15:45
подскажите, как установить определенный период для расчетов НУ УСН, допустим, только за январь 2012 (при установленной дате актуальности 01.01.0001.
22. Юрий Хрипачёв (hrip) 07.02.12 15:59
(21) irapronira, Не совсем понял вопрос насчет периода расчетов. Если имеется ввиду граница последовательности, то надо либо перепровести все документы, или скачать обработку которая может установить произвольную границу последовательности.
23. ира павлюк (irapronira) 08.02.12 08:43
А не подскажите ссылку, где есть обработка с установкой произвольной границы последовательности?
24. Юрий Хрипачёв (hrip) 08.02.12 09:20
(23) irapronira, Здесь же на инфостарте
напрмер
http://infostart.ru/public/16525/
http://infostart.ru/public/20953/
ну или поиском воспользуйся
25. ира павлюк (irapronira) 08.02.12 09:31
26. Олег Василевский (OlegrVasil) 16.02.12 16:01
Всё прекрасно отрабатывает. Спасибо большое разработчику.
27. jack jack (jack_kkm) 20.02.12 14:27
Автор, спасибо тебе, прям от души! Прям ваще! :)
Очень полезная обработка оказалась, днем ставлю запуск на вечер и спокойно иду домой.
28. Юрий Хрипачёв (hrip) 20.02.12 14:56
29. jack jack (jack_kkm) 21.02.12 06:39
hrip, скажи пожалуйста, где найти сообщение об ошибке списания по партионному учету, кроме окна сообщений? В логе нет, а хотелось бы. Получается, очистил окно и все ошибки потеряны?
30. Юрий Хрипачёв (hrip) 22.02.12 13:20
y(29) jack_kkm, насколько я знаю, то нигде
31. Sidor Petrov (1cinfo1) 01.03.12 18:03
Уже пару дней мучаюсь над тем, как запустить автоматически перепроведение в час ночи. Надеюсь ваша обработка поможет в этом
32. Sidor Petrov (1cinfo1) 01.03.12 18:45
Вот тоже интересный вариант http://infostart.ru/public/20238/
Буду пробовать допиливать под КОРП бухгалтерию
33. Александр *** (a1ex4ndr) 16.05.12 13:06
Под 8.1 никому не попадалась такая обработка?
34. ssvetusik (ssvetusik) 28.08.12 04:16
Хорошая обработка, как я поняла если будут транзакции то она остановиться?
35. Юрий Хрипачёв (hrip) 28.08.12 08:16
(34) ssvetusik, Остановиться только если вручную ограничить количество попыток запуска
36. andrey dyak (dyak84) 26.09.13 10:56
Автор работа клнечно зачетная слов нет но как быть с таким дело как последовательности. при работе твоей обработки все потом не будет красным.второй вопрос могу ли я выбрать 3 типадокументов и устанавить отбор по табличной части номенклатура.Зарание спасибо за ответ
37. Юрий Хрипачёв (hrip) 26.09.13 11:23
(36) dyak84, так обработка как раз и занимается тем что восстанавливает последовательности.
а как можно восстановить последовательность с отбором по типу документа(ов), если другие виды документов не перепроводить? Тогда в ней просто весь смысл теряется.
38. nikser Serov (nikser) 17.01.14 11:39
Ваша обработка не работает .Ставлю время когда начинать и когда заканчивать. Прихожу .База закрыта . Последовательность не восстановлена. какая причина .
1С:Предприятие 8.2 (8.2.18.82)
"Управление торговлей", редакция 10.3 (10.3.18.3) (http://v8.1c.ru/trade/)
Copyright (С) ООО "1C", 2003-2012. Все права защищены
(http://www.1c.ru)
39. Юрий Хрипачёв (hrip) 17.01.14 12:18
(38) nikser, Вашу проблему вероятно надо искать не в обработке т.к. в ней нигде не предусмотрено закрытие информационной базы. Да и описание проблемы никакое "Прихожу .База закрыта ." Попробуйте проследить что происходит во время запуска и выполнения обработки.
40. nikser Serov (nikser) 20.01.14 18:05
Спасибо за ответ . Проследить невозможно -по причине того, что прога просто закрывается .
Зашёл в монопольном режиме. Запустил. Результат на скрине вы видите . Что может быть ???
Везде ставил разное время - результат тот же.
Прикрепленные файлы:
41. nikser Serov (nikser) 20.01.14 18:07
Спасибо за ответ . Проследить невозможно -по причине того, что прога просто закрывается .
Зашёл в монопольном режиме. Запустил. Результат на скрине вы видите . Что может быть ???
Везде ставил разное время - результат тот же.
Прикрепленные файлы:
42. Cthutq Иванов (ewqewqewq) 28.05.14 17:29
Огромное спасибо.

Такой вопрос отменить обработку нельзя корректно? Только ждать окончание по времени?
Уточните что значит "запустить обработку в" при этом в это время должна быть открыта программа 1с или достаточно включенного компьютера ? спасибо.
43. SAshock 11.06.14 16:59
(20)hrip, по организациям не получилось сделать? очень надо )
44. Евгений (jo0506) 08.08.14 07:48
Допилить еще время окончания, если чек бокс не стоит на времени окончания, обработка не стартует...
WellMaster; +1 Ответить 1
45. WellMaster (WellMaster) 28.01.15 09:25
(44) jo0506,
кстати, да.
Скачал, запустил - не работает.
Прочитал коммент, поставил время окончания - запустилась.
46. Осипов Сергей (fixin) 27.12.15 23:12
Скачал сегодня в надежде, что за ночь отработает.
Ибо обычное восстановление вылетает по ошибке "Конфликт блокировок" и не делает повторных попыток.
Посмотрим, если эта софтина отработает до утра, то большое человеческое спасибо.
47. WWWolfy (WWWolfy) 25.04.16 22:41
Если не установить дату "Завершить выполнение обработки после", то берёт дефолтное "мДатаЗавершения = Дата(1, 1, 1, 0, 0, 0)"
и всегда срабатывает условие:
Если ТекущаяДата() >= ДатаЗавершенияВосстановления Тогда


т.е. сразу выходит из проведения.

Косячок..

исправить можно так:
дефолтДата = Дата(1, 1, 1, 0, 0, 0);
	
	// ■ Восстановление последовательностей
	// ■ периодами укаазанными шагом восстановления (в секундах)
	Пока ВосстанавливатьПоследовательность Цикл
		
		Если ТекущаяДата() >= ДатаЗавершенияВосстановления И (ДатаЗавершенияВосстановления<>дефолтДата) Тогда
...Показать Скрыть
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа