Полуавтоматическое обновление 1С посредством PowerShell

09.10.15

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

Прошу не кидать камни, первая публикация.
Итак, если вкратце: баз много, времени на обновление тратится безумно много. Решил автоматизировать часть работы посредством Powershell. Кому будет полезно, буду рад :)

Ниже описан алгоритм работы скрипта и пояснения к нему.

Алгоритм работы следующий:

1. Бэкапим базу

Для бэкапа используем запуск 1С из командной строки. В командной строке передаем путь к базе, в нашем случае база клиент-серверная, передаем имя сервера 1С и алиас базы на этом сервере, в случае если база файловая, то путь к папке с базой. Далее имя пользователя и пароль пользователя с правами администратора. Ключ /DumpIB говорит о том что базу нужно выгрузить. За место выгрузки и имя файла с базой отвечают переменные $WhereSaveDT  и $ArchiveName соответственно. Так же нам нужен лог файл куда 1С пишет результаты выполнения операции.

2. Если забэкапили успешно, начинаем обновлять

В случае, когда процесс отвечающий за бэкап базы вернул 0, т.е. выполнен бэкап без ошибок мы начинаем обновлять базу. Так же формируем строку из параметров, в целом они теже что и при бэкапе базы, отличие в ключе /UpdateCfg - ключ говорит о необходимости открыть базу и выполнить обновление. Так же тут важно значение переменной $ActualUpdateDir, в этой переменной содержится путь к папке с файлом обновления - 1cv8.cfu

3. Если не забэкапили, то пишем лог, и переходим к следующей базе.

Ну тут просто, если процесс, запускающий бэкап вернул значение отличное от 0, то базу не обновляем.

Так же, если по какой-то причине база не была обновлена, это можно сделать этим же скриптом, просто указав порядковый номер этой базы в переменной $count=0 и переменную $SelectedBase выставив в 0. Учитывайте, переменная $Path - массив, счет идет с нуля. Т.е. если нам нужно обновить вторую по порядку базу, то переменной $count нужно присвоить значение 1 

#Скрипт для бэкапа и обновления бухгалтерии 8.2
#С проверкой выполнения бэкапа

$Alias='База1','База2'
$Soft='C:\Program Files (x86)\1cv82\8.2.19.90\bin\1cv8.exe'
$ActualUpdateDir = '\\С:\tmplts\1c\Accounting\2_0_64_37\'
$WhereSaveDT='C:\Users\User\Desktop\Archives\Accounting\'
$Arg=''
$Path='"1C\База1"','"1C\База2"'
$Username='Администратор','Администратор'
$Password='123456','123456'
$count=0
#В случае, если count=n и SelecetdBase=0 - Обновляем все базы по списку начиная с базы с индексом n
#В случае, если count=n и SelecetdBase=1 - Обновляем только базу с индексом n
$count=0;
$SelectedBase=0;
if($SelectedBase -ne 1 ) {$LoopNum = $Alias.Count;}
Else {$LoopNum = $count;}


Do
    {
#Формируем имя файла для архива, состоит из даты и имени базы
$ArchiveName = Get-Date -Format d
$ArchiveName +=$Alias[$count]
#Формируем строку аргументов для запуска бэкапа базы
$Arg = "CONFIG /S" + $Path[$count] + " /N " + $Username[$count] + " /P " + $Password[$count]
$Arg += " /DumpIB " + $WhereSaveDT + $ArchiveName + ".dt" + " /Out " + $WhereSaveDT+$ArchiveName + ".txt " + "-NoTruncate"
$ps = new-object System.Diagnostics.Process
$ps.StartInfo.Filename = $Soft
$ps.StartInfo.Arguments = $Arg
$ps.StartInfo.RedirectStandardOutput = $True
$ps.StartInfo.UseShellExecute = $false
#Запускает процесс
$ps.start()
$ps.WaitForExit()
If($ps.ExitCode -eq 0) {
$ps.Close()
#Формируем строку аргументов для запуска обновления базы
$Arg = "CONFIG /S" + $Path[$count] + " /N " + $Username[$count] + " /P " + $Password[$count]
$Arg += " /UpdateCfg " + $ActualUpdateDir + "1cv8.cfu /UpdateDBcfg /Out " + $WhereSaveDT+$ArchiveName + ".txt " + "-NoTruncate"   
$ps = new-object System.Diagnostics.Process
$ps.StartInfo.Filename = $Soft
$ps.StartInfo.Arguments = $Arg
$ps.StartInfo.RedirectStandardOutput = $True
$ps.StartInfo.UseShellExecute = $false
#Запускает процесс
$ps.start()
$ps.WaitForExit()
$ps.Close()
}
Else {$ps.Close()}
$count+=1
$ArchiveName=''
    } While ($count -lt $LoopNum)

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

обновление выгрузка

См. также

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

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

14400 руб.

20.08.2024    50331    287    144    

260

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

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

16000 руб.

10.11.2023    21056    86    42    

95

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 1С 8.3 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, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 17.06.2025, версия 1.3

20400 руб.

06.12.2023    18854    69    10    

102

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

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

14400 руб.

29.04.2020    40692    122    152    

84

Инструменты администратора БД Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия Платные (руб)

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

12000 руб.

06.02.2017    34388    148    18    

53

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

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

6000 руб.

06.11.2012    76984    633    45    

91
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. CheBurator 3232 10.10.15 18:51 Сейчас в теме
Рнабираем в яндексе
Обновлятор 1с
A7758735; Evil Beaver; Papilion; +3 Ответить
2. virix 15 12.10.15 13:10 Сейчас в теме
(1) CheBurator, Да, да, теперь нашел. Перед тем как что-то писать изучал рынок, не нашел этого продукта :(
3. Stim213 417 15.10.15 10:18 Сейчас в теме
каждый одинесник, у которого более 5 баз пишет свой скрипт для обновления
7. Evil Beaver 8381 20.10.15 01:31 Сейчас в теме
(3) Stim213,
каждый одинесник, у которого более 5 баз пишет свой скрипт для обновления

.. а должен бы уже установить наконец билд-сервер!
4. ef42 19.10.15 11:42 Сейчас в теме
Спасибо, может и пригодиться.
5. virix 15 19.10.15 17:24 Сейчас в теме
(4) Созинов, Пожалуйста)
6. Evil Beaver 8381 20.10.15 01:30 Сейчас в теме


триста тридцать пять...
Для отправки сообщения требуется регистрация/авторизация