gifts2017

Автоматическое обновление конфигурации периферийного узла РИБ при обмене

Опубликовал Виталий Кондратьев (kondrat1C) в раздел Администрирование - Распределенная БД (УРИБ, УРБД)

При большом количестве периферийных узлов в РИБ достаточно проблематично производить обновление конфигурации. В данной статье опишу свой опыт решения данной проблемы.

Итак, имеется РИБ "1С:Розница 1.0" на платформе 8.1, в которой на данный момент 115 периферийных узлов. 

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

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

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

Заходим в режиме предприятия в периферийный узел и:

1. Сервис -> Обмен данными -> Настройка выполнения обменов
2. Выбираем нужную настройку и в пункте меню Действие выбираем подпункт "Настройка обновления конфигурации"
3. В открывшемся окне ставим галку на "Автоматически обновлять конфигурацию при приеме сообщения от главного узла"

 


4. В текстовом поле вставляем скрипт:
[CODE]
@echo off
set v8exe="C:\Program Files (x86)\1cv81\bin\1cv8.exe"
set DataBaseName="D:\1C_Base\"
set DataBase=/F%DataBaseName%

REM Логин администратора системы
set AdminUser=/N"Администратор" /p "пароль" /WA-

echo Завершение работы пользователей и установка блокировки...
start "" /wait %v8exe% ENTERPRISE %DataBase% %AdminUser% /CЗавершитьРаботуПользователей /DisableStartupMessages

echo .
echo Обновляем конфигурацию информационной базы
start "" /wait %v8exe% CONFIG %DataBase% %AdminUser% /UpdateDBCfg /UCКодРазрешения

echo .
echo Разрешение работы пользователей...
start "" /wait %v8exe% ENTERPRISE %DataBase% %AdminUser% /CРазрешитьРаботуПользователей /UCКодРазрешения /DisableStartupMessages
[/CODE]
правим объявленные в скрипте переменные под свои данные.

Теперь при приёме сообщения от центрального узла с обновлением конфигурации автоматически будет запускаться скрипт, который блокирует работу пользователей, обновляет конфигурацию, а затем разблокирует работу пользователей.

Есть один момент: если пользователь начал входить в ИБ и остановился на этапе авторизации, то платформа не может заблокировать такого пользователя (он же ещё не вошёл). В итоге конфигурация обновиться не может, т.к. нет монопольного доступа к ИБ.


Данный способ у меня работает уже с 2010 года. 

См. также

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

Комментарии

1. deadman66 (deadman66) 24.03.15 13:18
а ещё можно на форму настройки добавить поля для выбора пользователя, от чьего имени будет осуществляться обновление и поля для ввода\подтверждения пароля (звездочками отображалось что бы), а потом, при формировании скрипта для обновления брать данные для подстановки из этих полей, что бы не светить логин\пароль как на скриншоте у автора (такая система работает тоже очень давно у нас и не надо создавать в этом случае пользователя для обмена специального, все под штатным локальным админом выполняется). Ещё и исполняемый код в точках можно прикрутить, что бы после обновления при загрузке мессаджа в каждой точке выполнились назначенные действия (включение нового доп.права у продавца, например)
2. Программулькин (Программулькин) 25.03.15 04:06
start "" /wait %v8exe% ENTERPRISE %DataBase% %AdminUser% /CЗавершитьРаботуПользователей /DisableStartupMessages - эм...много вопросов остается:


А пароль где?
А если серверный вариант периферийных баз?
А если при выбросе пользователей юзверь останется висеть как сеанс в 1с сервере?
А для других конфигураций как?
3. Дмитрий Дидковский (didkovskij) 25.03.15 10:15
что то в Бухгалтерия предприятия КОРП, редакция 2.0 (2.0.64.12) я такого не могу найти :(
4. urbanist Железняков (urbanist) 25.03.15 10:28
(3) didkovskij,

В конфигурациях для бухгалтерии такой функционал не предусмотрен.
5. Андрей Акулов (DrAku1a) 26.03.15 02:27
(2) Ещё такой вопрос - а если сервер 1С предприятия и клиент - установлены на разных компьютерах - тогда как?
Кстати, даже если они на одной машине - есть косяк в 1С 8.2 с двойной авторизацией при первом запуске под пользователем. При этом даже если пароль указан в командной строке - диалог ввода пароля всё-равно вылезает...
У меня было такое решение: обработка, которая висит в фоне и периодически (раз в пять минут) - проверяет, нет ли изменений в конфигурации. Если изменения есть - запускается конфигуратор в режиме пакетного обновления. Для борьбы с двойной авторизацией - написана "простенькая" утилита (на Delphi) - работающая через WinAPI.
Сейчас сделал - чтобы сеанс не висел - цельную программу, которая коннектится к SQL-серверу напрямую и проверяет наличие обновлений (чтобы не висел постоянно сеанс в 1С). Но эта программка не всегда почему-то подцепляется к MS SQL. Да и нередко сервер перезагружают (а после перезагрузки - программка не запущена, т.к. никто под пользователем не зашёл). Так что - конечного решения пока что нету (((
6. nesa nesa (nesa) 26.03.15 05:30
(3) didkovskij,
Смотрите Обработки.ОбновлениеКонфигурации
7. aspirator 23 (aspirator23) 28.03.15 14:42
Для розничных периферийных баз, это наверное рисковано.
На кассе пробивают чек, а программа при автоматическом обмене завершает работу пользователей.
Да и для обычных вероятно тоже.
8. Виталий Кондратьев (kondrat1C) 03.04.15 10:31
(7) aspirator23, обновление конфигурации происходит только при запуске обмена данными. В момент обмена пользователи вообще не могут чеки бить, т.к. заблокированы таблицы итогов. Соответственно перед обменом все пользователи на кассах предупреждаются о начале обмена
9. Виталий Кондратьев (kondrat1C) 03.04.15 10:40
(2) Программулькин,
много вопросов остается:
А пароль где?

Пароль, как и имя пользователя содержится в переменной AdminUser

set AdminUser=/N"Администратор" /p "пароль" /WA-

start "" /wait %v8exe% ENTERPRISE %DataBase% %AdminUser% /CЗавершитьРаботуПользователей /DisableStartupMessages

А если серверный вариант периферийных баз?

для файлового варианта set DataBase=/F%DataBaseName%
для серверного - set DataBase=/S%DataBaseName%

А если при выбросе пользователей юзверь останется висеть как сеанс в 1с сервере?

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

А для других конфигураций как?

с РИБами других конфигураций не сталкивался

10. Виталий Кондратьев (kondrat1C) 03.04.15 10:47
(5) DrAku1a,
Ещё такой вопрос - а если сервер 1С предприятия и клиент - установлены на разных компьютерах - тогда как?

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

Кстати, даже если они на одной машине - есть косяк в 1С 8.2 с двойной авторизацией при первом запуске под пользователем. При этом даже если пароль указан в командной строке - диалог ввода пароля всё-равно вылезает...

эээ... как то не сталкивался с такой ситуацией, т.к. у нас РИБ на 8.1
кстати в ближайшее время буду РИБ в 115 узлов переводить на платформу 8.3... надеюсь не столкнусь с данной проблемой ))
11. Андрей Назаренко (Andy20151110) 10.11.15 15:03
Здраствуйте!

В 1С: Бухгалтерия 8.2.
При загрузке данных из ЦБ в ПБ возникает ошибка:
Начат обмен данными по настройке "Обмен с Периферийной базой" (12:37:14).
Объект не записан!
Не уникальный порядок элемента справочника.
Ошибка при чтении изменений при обмене РИБ: Ошибка при вызове метода контекста (ПрочитатьИзменения): Не удалось записать "Черновики (Группы писем электронной почты)"!
Чтение данных из файла обмена завершено с ошибками!
Обмен данными по настройке "Обмен с Периферийной базой" завершен (12:37:19).

Подскажите как решить?

Спасибо.
12. Виталий Кондратьев (kondrat1C) 12.11.15 16:46
(11) Andy20151110, в ЦБ сними с регистрации для обмена элемент справочника у которого неуникальный порядок. И повтори выгрузку из ЦБ в ПБ
А вообще, задумайся, а нужен ли обмен этим справочником
13. isn Игнатьев (isn) 02.12.15 16:00
(11) Проверьте в журнале регистрации на каком элементе "спотыкается" обмен. если справочник подразделения то есть вариант решения описанный на другом ресурсе (http://forum-1c.ru/index.php?topic=26780.0)
Как я понимаю это у вас в справочнике "Подразделения" образовалось...ТАК?
Тогда делать надо следующее:
1. в общем модуле справочника "Подразделения" исправить строку КонтролироватьПорядок = Истина;
на КонтролироватьПорядок = Ложь;
2. Затем перезапустить программу и с диск ИТС, с любого взять обработку «УниверсальныеПодборИОбработкаОбъектов.epf» и проставить в ней номера.
3. Далее строку КонтролироватьПорядок = Ложь; заменить на обратную КонтролироватьПорядок = Истина;.
4. Снова перезапустить программу.
14. Xer shi (Xershi) 28.04.16 11:48
Как эту штуку внедрить в любую конфигурацию?
15. Xer shi (Xershi) 02.05.16 16:53
Написал универсальный метод для любой конфигурации. Скоро оформлю публикацию.
16. Владимир Насыров (Spacer) 22.09.16 10:27
(15) Xershi, Как скоро ждать публикации?:)
17. Xer shi (Xershi) 22.09.16 14:01
(16) Spacer, я уже писал в своей теме. Нет времени на публикацию, чтобы была универсальной. Да и подзабыл, что куда добавлял. Во время внедрения нужно было документацию написать. Так что как только так сразу. Но не ждите в ближайшее время.
18. Денис Жуков (d.zhukov) 17.11.16 07:53
Автор, ваше решение не предусматривает фоновые сеансы в 1с. Спотыкается на завершении пользователей. Более того. после запуска вываливается сообщение "Установка соединений с информационной базой запрещена". Ни в конфигуратор, ни в предприятие не впускает. Исправьте, это серьезная ошибка в вашем алгоритме
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа