Регламент для обновления базы данных

28.04.17

Интеграция - Перенос данных 1C

Обработка для выполнения обновления узла. Работает как регламентное задание.

Файлы

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

Наименование Скачано Купить файл
Обновление конфигурации
.epf 8,98Kb
5 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Обработка загружается в дополнительные внешние обработки.

Далее нужно настроить расписание.

Принцип работы:

После выполнения обмена, при выполнении регламентного задания проверяется необходимость выполнения обновления.

Если нужно обновить - тогда всех выкинет из БД и запланирует задание на обновление конфигурации. Если обновление прошло удачно, тогда отключит выполнение задания.

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

Функция ЗавершитьСеансы()
	Результат = Истина;
	
	Блокировка = Новый БлокировкаСеансов;
	Блокировка.Установлена = Истина;
	Блокировка.Начало = ТекущаяДатаСеанса();
	Блокировка.КодРазрешения = "КодРазрешения";
	Блокировка.Сообщение = "Выполняется обновление. Сохраните данные и закройте 1С";
	УстановитьБлокировкуСеансов(Блокировка);
	
	Возврат Результат;
	
КонецФункции

Процедура ОбновлениеБД()
	//Пропишем пароль пользователя
	ПарольАдмина = Константы.Сударь_Администратор.Получить();
	Результат = "";
	
	Админ = Справочники.Пользователи.НайтиПоНаименованию("Администратор");
	Если ЗначениеЗаполнено(Админ.ИдентификаторПользователяИБ) Тогда
		ЗначХран = ПользователиИнформационнойБазы.НайтиПоУникальномуИдентификатору(Админ.ИдентификаторПользователяИБ);
		ЗначХран.Пароль	= ПарольАдмина;
		Попытка
			ЗначХран.Записать();
		Исключение
			Результат = "Не удалось записать пользователя.";
		Конецпопытки;
		
	КонецЕсли;
	
	//Запишем батник для обновления
	Если Результат = "" Тогда
		СтрокаСоединения = СтрокаСоединенияИнформационнойБазы();
		Если лев(СтрокаСоединения,4) = "Srvr" Тогда  
			Сервак = Лев(СтрокаСоединения,Найти(СтрокаСоединения,";Ref="));
			НачалоИБ = Найти(СтрокаСоединения,";Ref=")+5;
			НужноВзять = СтрДлина(СтрокаСоединения)- НачалоИБ;
			База   = Прав(СтрокаСоединения,НужноВзять);
			Сервак = СтрЗаменить(Сервак, "Srvr=", "");
			Сервак = СтрЗаменить(Сервак, ";", "");
			База = СтрЗаменить(База, ";", "");
			СтрокаСоединения = Сервак+"\"+База;
			СтрокаСоединения = СтрЗаменить(СтрокаСоединения, """", "");
			КаталогПрограммы = КаталогПрограммы();
			ИмяФайлаПрограммы = КаталогПрограммы + "\1cv8.exe";                       
			
			КоманднаяСтрокаОбновления = "echo off
			|cls
			|"""+ИмяФайлаПрограммы+""" CONFIG /S"""+СтрокаСоединения+""" /N""Администратор"" /P"""+ПарольАдмина+""" /DisableStartupMessages /UpdateDBCfg /UC""КодРазрешения""
			|"""+ИмяФайлаПрограммы+""" ENTERPRISE /S"""+СтрокаСоединения+""" /N""Администратор"" /P"""+ПарольАдмина+""" /DisableStartupMessages /C""РазрешитьРаботуПользователей"" /UC""КодРазрешения""";   		
		Иначе
			
			СтрокаСоединения = СтрЗаменить(СтрокаСоединения, "File=", "");
			СтрокаСоединения = СтрЗаменить(СтрокаСоединения, ";", "");
			КаталогПрограммы = КаталогПрограммы();
			ИмяФайлаПрограммы = КаталогПрограммы + "\1cv8.exe";                       
			
			КоманднаяСтрокаОбновления = "echo off
			|cls
			|"""+ИмяФайлаПрограммы+""" CONFIG /F"+СтрокаСоединения+" /N""Администратор"" /P"""+ПарольАдмина+""" /DisableStartupMessages /UpdateDBCfg /UC""КодРазрешения""
			|"""+ИмяФайлаПрограммы+""" ENTERPRISE /F"+СтрокаСоединения+" /N""Администратор"" /P"""+ПарольАдмина+""" /DisableStartupMessages /C""РазрешитьРаботуПользователей"" /UC""КодРазрешения""";   		
		КонецЕсли;
		
		ИмяФайлаСкрипта = "C:\run1С.bat";
		Ф = Новый ТекстовыйДокумент();
		Ф.УстановитьТекст(КоманднаяСтрокаОбновления);
		Ф.Записать(ИмяФайлаСкрипта, КодировкаТекста.OEM);
		Результат = "Выполнено";
	КонецЕсли;
	
	//Запишем схему для создания задания
	Если Результат = "Выполнено" Тогда
		WSH = Новый COMobject("wscript.network");
		ИмяКомпьютера = WSH.ComputerName;
		ИмяПользователя = WSH.UserName;
		
		ТекстХМЛ = "<?xml version=""1.0"" encoding=""UTF-16""?>
		|<Task version=""1.2"" xmlns=""http://schemas.microsoft.com/windows/2004/02/mit/task"">
		|  <RegistrationInfo>
		|    <Date>2017-04-05T16:11:32.542172</Date>
		|    <Author>"+ИмяКомпьютера+"\"+ИмяПользователя+"</Author>
		|    <Description>Запускаем обновление и затем пускаем пользователей и выполняем синхронизацию с центром</Description>
		|  </RegistrationInfo>
		|  <Triggers>
		|    <CalendarTrigger>
		|      <Repetition>
		|        <Interval>PT5M</Interval>
		|        <Duration>P1D</Duration>
		|        <StopAtDurationEnd>false</StopAtDurationEnd>
		|      </Repetition>
		|      <StartBoundary>2017-04-06T08:00:00</StartBoundary>
		|      <Enabled>true</Enabled>
		|      <ScheduleByDay>
		|        <DaysInterval>1</DaysInterval>
		|      </ScheduleByDay>
		|    </CalendarTrigger>
		|    <RegistrationTrigger>
		|      <Enabled>true</Enabled>
		|      <Delay>PT30S</Delay>
		|    </RegistrationTrigger>
		|  </Triggers>
		|  <Principals>
		|    <Principal id=""Author"">
		|      <UserId>"+ИмяКомпьютера+"\"+ИмяПользователя+"</UserId>
		|      <LogonType>InteractiveToken</LogonType>
		|      <RunLevel>HighestAvailable</RunLevel>
		|    </Principal>
		|  </Principals>
		|  <Settings>
		|    <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
		|    <DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
		|    <StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
		|    <AllowHardTerminate>true</AllowHardTerminate>
		|    <StartWhenAvailable>true</StartWhenAvailable>
		|    <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
		|    <IdleSettings>
		|      <StopOnIdleEnd>true</StopOnIdleEnd>
		|      <RestartOnIdle>false</RestartOnIdle>
		|    </IdleSettings>
		|    <AllowStartOnDemand>true</AllowStartOnDemand>
		|    <Enabled>true</Enabled>
		|    <Hidden>false</Hidden>
		|    <RunOnlyIfIdle>false</RunOnlyIfIdle>
		|    <WakeToRun>false</WakeToRun>
		|    <ExecutionTimeLimit>PT4H</ExecutionTimeLimit>
		|    <Priority>7</Priority>
		|    <RestartOnFailure>
		|      <Interval>PT1M</Interval>
		|      <Count>3</Count>
		|    </RestartOnFailure>
		|  </Settings>
		|  <Actions Context=""Author"">
		|    <Exec>
		|      <Command>C:\run1С.bat</Command>
		|    </Exec>
		|  </Actions>
		|</Task>";
		
		ИмяФайлаСкрипта = "C:\Run1C_Task.xml";
		Ф = Новый ТекстовыйДокумент();
		Ф.УстановитьТекст(ТекстХМЛ);
		Ф.Записать(ИмяФайлаСкрипта, КодировкаТекста.UTF16);
		Результат = "Записано";
	КонецЕсли;
	
	Если Результат = "Записано" Тогда
		ТекстБатника  ="
		|@echo off
		|Rem action - установка значение disable или enable 
		|set task_action=enable 
		|REM Проверка наличия прав администратора
		|REM @WHOAMI /PRIV | find /i ""SeRemoteShutdownPrivilege"" > nul
		|REM if %ERRORLEVEL% == 0 goto admin
		|REM echo Execution aborted. Run this batch file AS Administrator  !!!
		|REM pause
		|REM exit
		|REM :admin
		|REM @echo try %task_action% scheduled tasks ...  
		|schtasks /Create /XML c:\Run1C_Task.xml /TN ""Run1C_Task""
		|schtasks /change /tn ""\Run1C_Task"" /%task_action% >> %~dn0.log";
		
		ИмяФайлаСкрипта = "C:\schtasks.bat";
		Ф = Новый ТекстовыйДокумент();
		Ф.УстановитьТекст(ТекстБатника);
		Ф.Записать(ИмяФайлаСкрипта, КодировкаТекста.OEM);
		Результат = "Можно запускать";
	КонецЕсли;
	
	Если Результат = "Можно запускать" Тогда
		Попытка
			ЗапуститьПриложение(ИмяФайлаСкрипта,,ложь);      
		Исключение
		КонецПопытки;
	КонецЕсли;
	
КонецПроцедуры


Процедура ОтключитьПланировщик()
	ТекстБатника  ="
	|@echo off
	|Rem action - установка значение disable или enable 
	|set task_action=disable 
	|REM Проверка наличия прав администратора
	|REM @WHOAMI /PRIV | find /i ""SeRemoteShutdownPrivilege"" > nul
	|REM if %ERRORLEVEL% == 0 goto admin
	|REM echo Execution aborted. Run this batch file AS Administrator  !!!
	|REM pause
	|REM exit
	|REM :admin
	|REM @echo try %task_action% scheduled tasks ...  
	|schtasks /Create /XML c:\Run1C_Task.xml /TN ""Run1C_Task""
	|schtasks /change /tn ""\Run1C_Task"" /%task_action% >> %~dn0.log";
	
	ИмяФайлаСкрипта = "C:\schtasks.bat";
	Ф = Новый ТекстовыйДокумент();
	Ф.УстановитьТекст(ТекстБатника);
	Ф.Записать(ИмяФайлаСкрипта, КодировкаТекста.OEM);
	Попытка
		ЗапуститьПриложение(ИмяФайлаСкрипта,,ложь);      
	Исключение
	КонецПопытки;
	
КонецПроцедуры

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

50050 руб.

25.02.2015    186516    349    283    

411

Перенос данных 1C Программист 1С:Предприятие 8 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

58000 руб.

04.08.2015    184382    427    298    

438

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

22650 руб.

12.06.2017    157952    945    317    

476

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.264.x) и БП 3.0 (3.0.192.x). Правила подходят для версии ПРОФ и КОРП.

38000 руб.

15.12.2021    32580    242    61    

182

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.25.x).

38000 руб.

23.07.2020    66082    308    84    

247

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист 1С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Платные (руб)

Правила переноса кадровых и расчетных данных и справочной информации из "1С:УПП1.3" или "1С:КА 1.1" в "1С:ЗУП 3.1 | Разработан в формате КД 2 (правила конвертации данных) | При выгрузке есть фильтр по организациям | Обновляется при выходе новых релизов 1С | Развитие алгоритмов | Расчетные документы переносятся в документ "Перенос данных" | Создаются документы "Начальная штатная расстановка" и "Начальная задолженность по зарплате", переносятся кадровые документы

58000 руб.

29.10.2018    61354    77    128    

76

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Платные (руб)

Перенос данных из ЗУП 3 в ЗУП 3 | из ЗУП 3 в КА 2 | из ЗУП 3 в ERP | Оперативно обновляется при выходе новых релизов 1С | Готовые правила конвертации (КД 2) для перехода с "ЗУП 3" на "УП ред. 3" / "КА, ред. 2" / "ERP, ред. 2" |Переносится нормативно-справочная информация и документы с движениями

55200 руб.

11.01.2021    37214    33    56    

35

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Россия Платные (руб)

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 3, УНФ 3 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

16531 руб.

18.02.2016    199669    662    543    

559
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. TODD22 20 19.10.16 11:37 Сейчас в теме
Что то не получается этой обработкой обновить. Изменил конфигурацию, запустил обновление. Теперь в базу попасть не могу. Висит блокировка и ожидание запуска....
2. TODD22 20 19.10.16 11:46 Сейчас в теме
Судя по журналу регистрации проблема в каком то фоновом задании которое выполняется параллельно и не может быть завершено.
3. TODD22 20 19.10.16 17:09 Сейчас в теме
А у вас на сколько стабильно механизм обновлений работает?
Получается что если обновление началось и не завершилось например из за выполнявшегося в этот момент фонового задания то в базу потом зайти не даёт. Зависает блокировка... В принципе мне можно не ставить блокировку. это нужно руками удалять файл блокировки что для рядового пользователя сложная задача. Ещё что нибудь не то удалит :)
4. Pira 154 27.10.16 15:38 Сейчас в теме
(3) TODD22, Я пользуюсь в таких случаях батником, который запускает БД с ключем разрешения работы пользователей. По стабильности: В последнем обновлении пришлось подключаться к 6 магазинам из 48.
5. TODD22 20 27.10.16 17:52 Сейчас в теме
Можно батник написать который удаляет файл блокировки из каталога с базой. Я думаю пойти по такому пути.

6. Pira 154 28.04.17 12:17 Сейчас в теме
Переписал выполнение обновления через планировщик заданий. Теперь обновление выполняется автоматом в во всех узлах.
Для отправки сообщения требуется регистрация/авторизация