Bash-скрипт обновления конфигураций 1С по расписанию на сервере CentOS 7

26.04.19

Разработка - Инструментарий разработчика

Скрипт позволяет обновлять конфигурации 1С, находящиеся на поддержке, непосредственно на самом сервере 1С Предприятие под управлением CentOS 7 без установки графического окружения.

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Bash-скрипт обновления конфигураций 1С по расписанию на сервере CentOS 7:
.zip 5,34Kb
39 1 850 руб. Купить

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

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

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

Как обновлять конфигурации на поддержке используя команды пакетного режима запуска  в среде Windows  многие знают. Однако обязательным условием запуска клиента 1С является наличие графического окружения (иксов). Чтобы использовать пакетный режим под CentOS и не устанавливать "окна", можно использовать пакет Xvfb, рекомендуемый 1С (https://its.1c.ru/db/freshpub/content/105/hdoc). Предлагаемый скрипт как раз и использует эту возможность.

Порядок действий скрипта:

  1. Считывает файлы заданий из каталога
  2. Проверяет флаг активности задания и существования файла обновлений
  3. Сравнивает время задачи с текущей датой
  4. проверяет установку Xvfb и, в случае необходимости устанавливает
  5. Устанавливает блокировку регламентных задание и сеансов
  6. Создает резервную копию средствами PostgreSQL
  7. Обновляет конфигурацию из файла
  8. Обновляет конфигурацию информационной базы
  9. Запускает конфигурацию в режиме 1С Предприятия для выполнения процедур обновления
  10. Снимает блокировку регламентных задание и сеансов

Перед началом работы необходимо установить толстый клиент (для этого я и включил установку толстого клиента в скрипт)

Установка и настройка:

  • Сам скрипт записывается в любой каталог. В этот же каталог копируем файл update.epf
  • Настраиваем переменные в начале скрипта:

SERVER="192.168.0.10" - адрес кластера

BLOCK_CODE="123"  - код для блокировки информационной базы (см. параметр пакетного запуска /UC )

SHEDULE_DIR=/home/files/install  - каталог поиска файлов заданий, например "расшаренный" samba

  • устанавливает права на запуск chmod +x update_cfg.sh
  • чтобы на застрять в vim и не выключать компьютер :-) , выполните export EDITOR=nano (или mcedit)
  • командой crontab -e добавляем задание запускать каждые 5 минут в cron (указываем полный путь к файлу update_cfg.sh):

*/5 * * * * /root/update_cfg.sh

Теперь каждые 5 минут скрипт будет искать задачи в каталоге SHEDULE_DIR и выполнять необходимые действия (другой вариант запускать один раз, скажем в 23:00)

Файл задания имеет расширение *.upd.1c и следующую структуру:

DB_NAME=zgu

имя базы в кластере

DB_USR=Админ

Логин пользователя с полными правами и отключенным флагом "защита от опасных действий"

DB_PWD=123

Пароль соответственно

FILE=/home/files/install/1cv8.cf

Файл обновления *.cfu, *.cf

BK_DIR=/home/files/install

Каталог, в который будет записана резервная копия

NEW_VER=3.1.9.28

Номер версии, чисто для отображения в сообщении блокировки

TIME=2019-04-08 10:01:00

Дата и время запуска

STATUS=OFF

Статус активности задания ON/OFF

 
Разумеется не забываем о безопасности - файлы скрипта, заданий и  update.epf не должны быть доступны простым пользователям. Так же запуск скрипта через cron можно сделать от имени пользователя usr1cv8 (crontab -u usr1cv8 -e). Но в этом случае установку и управление службой Xvfb.service следует исключить из тела скрипта и установить запуск про старте системы systemctl enable Xvfb.service.

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

Linux CentOS PostgreSQL Обновление

См. также

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

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    205945    1131    410    

1029

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

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

8400 руб.

20.08.2024    36895    211    111    

198

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

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

16000 руб.

10.11.2023    16803    73    39    

89

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

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    24391    65    28    

93

Инструментарий разработчика Программист 1С v8.3 1С:Управление нашей фирмой 3.0 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9500 руб.

17.05.2024    35349    128    53    

170

SALE! 30%

Инструментарий разработчика WEB-интеграция 1С v8.3 1C v8.2 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 12600 руб.

22.11.2024    2024    1    0    

8

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

6000 руб.

07.02.2018    107720    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. edelweiss 27.04.19 15:02 Сейчас в теме
На этом сайте такому простому, грешному быдлу, как я, великими местными гуру не разрешено переписываться с пользователями, но Ваши сообщения, которые Вы писали, я увидел, поэтому, если Вы оставите свой контакт для связи, - буду очень признателен!
2. Sedaiko 597 27.04.19 17:45 Сейчас в теме
3. bonus777 29.04.22 10:16 Сейчас в теме
Добрый день. Скачал скрипт, настроил для связки postgres 13 и 1С сервер 8.3.19 на одной машине. Установил толстый клиент. Отключил опасные действия. Проверил в скрипте все пути и параметры запуска исполняемых файлов. В итоге, базы находит, регламентные задания и соединения запрещает, файлы обновления находит, id кластера и базы получает (кстати для grep пришлось прописать параметр -w, т.к. базу TEST и TEST1 он считает одним и тем же), делает бекап, запускает конфигуратор с параметрами как положено и все. Больше ничего не происходит много часов. Вижу в списках сеансов к обновляемой базе конфигуратор и все. Застревает на стадии загрузки обновления в конфигураторе. Глазами на проблему посмотреть не могу. Может подскажите как vnc подключиться?
4. Sedaiko 597 29.04.22 11:28 Сейчас в теме
5. bonus777 29.04.22 11:44 Сейчас в теме
(4) Пишет, что лицензия не обнаружена. Как указать ему сетевую лицензию? Есть сетевой ключ на 100 подключений.
6. Sedaiko 597 29.04.22 12:20 Сейчас в теме
(5) создать каталог conf и запихнуть туда nethasp.ini
https://its.1c.ru/db/v8318doc#bookmark:adm:TI000000291
7. bonus777 29.04.22 12:24 Сейчас в теме
Огромное спасибо, что объясняете. Ни одну из этих статей не нашел поиском.
8. bonus777 29.04.22 13:32 Сейчас в теме
Sedaiko, получилось, запустился конфигуратор, увидел ключ. Но теперь требует подтверждения обновления конфигурации. Как это обойти?
9. Sedaiko 597 29.04.22 13:49 Сейчас в теме
Давно делал. Сейчас нужно чтобы были параметры /DisableStartupMessages и /DisableStartupDialogs
10. bonus777 29.04.22 14:23 Сейчас в теме
Добавил в параметры запуска. Теперь в vnc вообще окно конфигуратора не показывается, но соединение с БД идет.
/opt/1cv8/x86_64/8.3.19.1467/1cv8 DESIGNER /IBConnectionString"Srvr="""$SERVER""";Ref="""$DB""";" /N$USR /P$PWD /UC$BLOCK_CODE /Out"/home/usr1cv8/out_"$DB".txt" /DumpResult"/home/usr1cv8/DumpResult_"$DB".txt" /UpdateCfg $FILE /DisableStartupMessages /DisableStartupDialogs
11. bonus777 29.04.22 14:55 Сейчас в теме
А предприятие тоже надо запускать с ключами /DisableStartupMessages и /DisableStartupDialogs ???
Можно ли как-то обойти галочку "я подтверждаю что конфигурация лицензионная и т.д."? Извините за кучу вопросов.
12. Sedaiko 597 30.04.22 00:52 Сейчас в теме
(11) Обновленная обработка.
Запускать два раза в режиме Предприятие.
Прикрепленные файлы:
upd.epf
pshunailov; +1 Ответить
13. bonus777 03.05.22 16:47 Сейчас в теме
Все получилось. Работает отлично. Спасибо.
14. chalker 04.07.25 12:41 Сейчас в теме
Класс! До сих пор работает, сейчас проверил!
pshunailov; +1 Ответить
Оставьте свое сообщение