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

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

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

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

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

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

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

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

 

4. В текстовом поле вставляем скрипт:
[CODE]
@echo off
set v8exe=»C:Program Files (x86)1cv81in1cv8.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 года. 

20 Comments

  1. deadman66

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

    Reply
  2. Программулькин

    start «» /wait %v8exe% ENTERPRISE %DataBase% %AdminUser% /CЗавершитьРаботуПользователей /DisableStartupMessages — эм…много вопросов остается:

    А пароль где?

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

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

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

    Reply
  3. didkovskij

    что то в Бухгалтерия предприятия КОРП, редакция 2.0 (2.0.64.12) я такого не могу найти 🙁

    Reply
  4. urbanist

    (3) didkovskij,

    В конфигурациях для бухгалтерии такой функционал не предусмотрен.

    Reply
  5. DrAku1a

    (2) Ещё такой вопрос — а если сервер 1С предприятия и клиент — установлены на разных компьютерах — тогда как?

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

    У меня было такое решение: обработка, которая висит в фоне и периодически (раз в пять минут) — проверяет, нет ли изменений в конфигурации. Если изменения есть — запускается конфигуратор в режиме пакетного обновления. Для борьбы с двойной авторизацией — написана «простенькая» утилита (на Delphi) — работающая через WinAPI.

    Сейчас сделал — чтобы сеанс не висел — цельную программу, которая коннектится к SQL-серверу напрямую и проверяет наличие обновлений (чтобы не висел постоянно сеанс в 1С). Но эта программка не всегда почему-то подцепляется к MS SQL. Да и нередко сервер перезагружают (а после перезагрузки — программка не запущена, т.к. никто под пользователем не зашёл). Так что — конечного решения пока что нету (((

    Reply
  6. nesa

    (3) didkovskij,

    Смотрите Обработки.ОбновлениеКонфигурации

    Reply
  7. aspirator23

    Для розничных периферийных баз, это наверное рисковано.

    На кассе пробивают чек, а программа при автоматическом обмене завершает работу пользователей.

    Да и для обычных вероятно тоже.

    Reply
  8. kondrat1C

    (7) aspirator23, обновление конфигурации происходит только при запуске обмена данными. В момент обмена пользователи вообще не могут чеки бить, т.к. заблокированы таблицы итогов. Соответственно перед обменом все пользователи на кассах предупреждаются о начале обмена

    Reply
  9. kondrat1C

    (2) Программулькин,

    много вопросов остается:

    А пароль где?

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

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

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

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

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

    для серверного — set DataBase=/S%DataBaseName%

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

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

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

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

    Reply
  10. kondrat1C

    (5) DrAku1a,

    Ещё такой вопрос — а если сервер 1С предприятия и клиент — установлены на разных компьютерах — тогда как?

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

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

    эээ… как то не сталкивался с такой ситуацией, т.к. у нас РИБ на 8.1

    кстати в ближайшее время буду РИБ в 115 узлов переводить на платформу 8.3… надеюсь не столкнусь с данной проблемой ))

    Reply
  11. Andy20151110

    Здраствуйте!

    В 1С: Бухгалтерия 8.2.

    При загрузке данных из ЦБ в ПБ возникает ошибка:

    Начат обмен данными по настройке «Обмен с Периферийной базой» (12:37:14).

    Объект не записан!

    Не уникальный порядок элемента справочника.

    Ошибка при чтении изменений при обмене РИБ: Ошибка при вызове метода контекста (ПрочитатьИзменения): Не удалось записать «Черновики (Группы писем электронной почты)»!

    Чтение данных из файла обмена завершено с ошибками!

    Обмен данными по настройке «Обмен с Периферийной базой» завершен (12:37:19).

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

    Спасибо.

    Reply
  12. kondrat1C

    (11) Andy20151110, в ЦБ сними с регистрации для обмена элемент справочника у которого неуникальный порядок. И повтори выгрузку из ЦБ в ПБ

    А вообще, задумайся, а нужен ли обмен этим справочником

    Reply
  13. isn

    (11) Проверьте в журнале регистрации на каком элементе «спотыкается» обмен. если справочник подразделения то есть вариант решения описанный на другом ресурсе (http://forum-1c.ru/index.php?topic=26780.0)

    Как я понимаю это у вас в справочнике «Подразделения» образовалось…ТАК?

    Тогда делать надо следующее:

    1. в общем модуле справочника «Подразделения» исправить строку КонтролироватьПорядок = Истина;

    на КонтролироватьПорядок = Ложь;

    2. Затем перезапустить программу и с диск ИТС, с любого взять обработку «УниверсальныеПодборИОбработкаОбъектов.epf» и проставить в ней номера.

    3. Далее строку КонтролироватьПорядок = Ложь; заменить на обратную КонтролироватьПорядок = Истина;.

    4. Снова перезапустить программу.

    Reply
  14. Xershi

    Как эту штуку внедрить в любую конфигурацию?

    Reply
  15. Xershi

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

    Reply
  16. Spacer

    (15) Xershi, Как скоро ждать публикации?:)

    Reply
  17. Xershi

    (16) Spacer, я уже писал в своей теме. Нет времени на публикацию, чтобы была универсальной. Да и подзабыл, что куда добавлял. Во время внедрения нужно было документацию написать. Так что как только так сразу. Но не ждите в ближайшее время.

    Reply
  18. d.zhukov

    Автор, ваше решение не предусматривает фоновые сеансы в 1с. Спотыкается на завершении пользователей. Более того. после запуска вываливается сообщение «Установка соединений с информационной базой запрещена». Ни в конфигуратор, ни в предприятие не впускает. Исправьте, это серьезная ошибка в вашем алгоритме

    Reply
  19. 88wau24ru

    (10)

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

    Ни знаю актуально нет, но данная ошибка исчезает при «Аутентификации Windows»

    Reply
  20. Xershi

    (16) уже давно опубликовал и забыл оповестить: http://infostart.ru/public/570963/

    Пользуйтесь на здоровье!

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *