Полуавтоматическое обновление 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С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

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

8400 руб.

20.08.2024    14672    108    46    

108

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

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

15000 руб.

10.11.2023    11960    45    33    

67

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 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    10747    47    8    

78

SALE! %

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

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

4800 3840 руб.

14.01.2013    191349    1153    0    

920

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

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

14400 руб.

29.04.2020    33867    108    152    

75

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

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

3600 руб.

06.02.2017    32679    145    18    

51

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

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

6000 руб.

06.11.2012    73778    629    45    

88

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

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

3000 руб.

21.07.2022    10181    10    4    

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

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


триста тридцать пять...
Оставьте свое сообщение