Автоматический перезапуск рабочих процессов (rphost) кластера 1С

20.01.23

Администрирование - Сервера

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

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
1C RpHost Manager win-x64
.zip 869,09Kb
13 4 550 руб. Купить
1C RpHost Manager win-x86
.zip 857,75Kb
1 4 550 руб. Купить

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

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

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

Исходный код разработки на GitHub

Поддерживаемая версия платформы 1С: 8.3.15 и выше.

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

Средства управления кластером 1С не позволяют настраивать перезапуск одного рабочего процесса в случае превышения им установленного лимита памяти. Данная разработка призвана решить именно эту конкретную задачу.

В случае превышения установленного лимита расхода  памяти на один рабочий процесс служба rphost-manager регулирует свойство TemporaryAllowedProcessesTotalMemory (временно допустимый объём памяти всех рабочих  процессов)   соответствующего рабочего сервера таким образом, чтобы менеджер кластера 1С начал перезапуск его rphost'ов штатными средствами. После перезапуска служба rphost-manager возвращает эти настройки к исходным значениям.

 

Установка службы rphost-manager

  1. Установить .NET Core 3.1.
  2. Установить COMConnector 1C, выполнив команду от имени администратора:
regsvr32 "C:\Program Files\1cv8\8.3.15.1778\bin\comcntr.dll"
  1. Распаковать содержимое установочного архива в любой каталог.
  2. Установить сервис Windows, выполнив команду от имени администратора:
sc create "1C RpHost Manager" binPath="D:\RphostManager\rphost-manager.exe"

 

Описание настроек службы rphost-manager

  • LogSize - размер лога программы в байтах. По достижению этого лимита файл лога перезаписывается.
  • CLSID - идентификатор COM объекта "V83.COMConnector". Данная настройка используется только в том случае, если она заполнена. В противном случае используется ProgID "V83.COMConnector".
  • InspectionPeriodicity - периодичность инспекции объёма памяти, используемого rphost'ами, в секундах.
  • ServerAddress - адрес центрального сервера 1С.
  • UserName - имя пользователя для подключения к кластеру 1С.
  • Password - пароль пользователя для подключения к кластеру 1С.
  • WorkingServerResetWaitTime - период ожидания переключения rphost'ов менеджером кластера 1С в нерабочее состояние в секундах.
  • WorkingProcessMemoryLimit - лимит памяти для одного rphost'а в килобайтах. Используется только в том случае, если не определён список индивидуальных настроек для рабочих серверов WorkingServerMemoryLimits.
  • WorkingServerMemoryLimits - список рабочих серверов 1С, которые нужно инспектировать, и лимит памяти rphost'а для каждого сервера в отдельности. Если список пустой, то инспектируются все сервера кластера, а в качестве лимита памяти rphost'а используется настройка WorkingProcessMemoryLimit. Если сервер не указан, то его инспекция не производится.

 

Пример настройки для всех рабочих серверов кластера 1С

Лимит памяти для одного рабочего процесса для всех рабочих серверов установлен на уровне 4 Gb

{
  "LogSize": 131072,
  "CLSID": "",
  "InspectionPeriodicity": 180,
  "ServerAddress": "tcp://MSK01:1540",
  "UserName": "",
  "Password": "",
  "WorkingServerResetWaitTime": 10,
  "WorkingProcessMemoryLimit": 4194304,
  "WorkingServerMemoryLimits": {},
  "HostOptions": {
    "ShutdownTimeout": "00:00:30"
  }
}

 

Пример индивидуальной для рабочих серверов настройки

Для сервера MSK01-SRV01 установлен лимит памяти одного рабочего процесса на уровне 1 Gb

Для сервера MSK01-SRV02 установлен лимит памяти одного рабочего процесса на уровне 2 Gb

Настройка WorkingProcessMemoryLimit игнорируется.

Важно: имена серверов указываются так, как они отображаются в консоли управления кластером 1С.

{
  "LogSize": 262144,
  "CLSID": "181E893D-73A4-4722-B61D-D604B3D67D47",
  "InspectionPeriodicity": 300,
  "ServerAddress": "tcp://MSK01:1540",
  "UserName": "",
  "Password": "",
  "WorkingServerResetWaitTime": 10,
  "WorkingProcessMemoryLimit": 2097152,
  "WorkingServerMemoryLimits": {
    "MSK01-SRV01": 1048576,
    "MSK01-SRV02": 2097152
  },
  "HostOptions": {
    "ShutdownTimeout": "00:00:30"
  }
}

 

Разработка прошла опытно-промышленную эксплуатацию на кластере из 4-х рабочих серверов 1С. Показала себя успешно. Иногда используется для ситуативного перезапуска какого-нибудь одного "распухшего" рабочего процесса.

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

rphost

См. также

Администрирование веб-серверов Сервера Нейросети Программист Платные (руб)

Сервер поиска по метаданным и поиска по коду, Сервер экспорта и поиска по документации, Сервер синтаксической проверки кода

17.06.2025    3847    57    comol    5    

27

Сервера Системный администратор Бесплатно (free)

В этой статье мы подробно разберем процесс настройки встроенного в PostgresPRO отказоустойчивого решения — кластера BiHA. Установим, настроим, протестируем отказ лидера и проверим автоматическое переключение ролей. А также интегрируем кластер с сервером 1С и проанализируем его реакцию на смену лидера.

30.06.2025    1037    a.doroshkevich    0    

8

Администрирование веб-серверов Сервера Системный администратор Программист Абонемент ($m)

WEB приложение для управления сеансами сервера 1С, имеет адаптивный web интерфейс. Возможности: удаление сеансов; завершение rphost процессов; запуск службы 1С сервера (если остановлена). Используется авторизация BasicAuth с защитой от брутфорса. Поддерживает работу по http https протоколам.

1 стартмани

08.11.2024    1736    12    gortrex    2    

3

Облачные сервисы, хостинг Linux Тестирование QA Сервера Системный администратор Программист 1С v8.3 Бесплатно (free)

Завершающая публикация цикла "В облако на работу:.. Рецепты от Капитана", в ходе которых был собран полнофункциональный рабочий контур 1С в сети на отечественной Ред ОС. С веб-серверами, доменной авторизацией, архивированием, отказоустойчивостью и прочая, прочая... В этой статье мы определяемся с быстродействием системы, проводим нагрузочное тестирование и отпускаем ее в свободное плавание (зачеркнуто) выпускаем ее в продуктовый контур, где, конечно же, придется отлавливать ошибки, мониторить состояние и т.п.

31.10.2024    2308    capitan    0    

0

Сервера Системный администратор Бесплатно (free)

На первый взгляд, добавление второго сервера в кластер 1С не должно вызывать проблем – все просто должно работать. Но на практике дело обстоит иначе. Несмотря на то, что все действительно работает, многие при этом сталкиваются с трудностями. Расскажем, когда нужно задуматься о втором сервере 1С в кластере, какие особенности работы второго сервиса с файлами и сервисами, и какие настройки ТНФ можно сделать для лицензий ПРОФ и КОРП.

31.10.2024    16427    a.doroshkevich    23    

76

Сервера Системный администратор Программист Бесплатно (free)

Отдельный сервер лицензирования упрощает администрирование лицензий в сложных структурах с несколькими кластерами и тысячами пользователей. Расскажем о том, как настроить резервирование лицензий для крупной компании с высокими требованиями к доступности SLA 99.98% и автоматизировать переактивацию лицензий в случае возможных сбоев.

29.10.2024    5823    jul.dolganova    14    

18

Облачные сервисы, хостинг Linux Сервера Системный администратор Программист 1С v8.3 Бесплатно (free)

Одна из завершающих публикаций цикла "В облако на работу:.. Рецепты от Капитана", в ходе которых был собран полнофункциональный рабочий контур 1С в сети на отечественной Ред ОС. С веб-серверами, доменной авторизацией, архивированием и прочая, прочая... На закуску разбираемся с отказоустойчивостью. В этой публикации для серверов 1С заодно попробуем подобно сериалу «Разрушители легенд» подтвердить или опровергнуть пару устойчивых мифов о требованиях назначения функциональности.

18.10.2024    3820    capitan    6    

13
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. user1198184 28.01.23 19:10 Сейчас в теме
Добрый всем день, вечер :)

Коллеги, а кто-то пользовался этой утилитой?

Я хотел поставить на два сервера - на одном без проблем встала и отлично работает. А вот на втором затык с COM+ объектами...
Не могу решить...
В логах вот такая ошибка:

[дата-время] V83.COMConnector initialized successfully.
[дата-время] Connecting tcp://192.168.2.254:1540 ...
[дата-время] Failed to connect tcp://192.168.2.254:1540.
Library not registered. (0x8002801D (TYPE_E_LIBNOTREGISTERED))
[дата-время] Connecting tcp://192.168.2.254:1540 ...
[дата-время] Failed to connect tcp://192.168.2.254:1540.
Library not registered. (0x8002801D (TYPE_E_LIBNOTREGISTERED))
[дата-время] Connecting tcp://192.168.2.254:1540 ...
[дата-время] Failed to connect tcp://192.168.2.254:1540.
Library not registered. (0x8002801D (TYPE_E_LIBNOTREGISTERED))

и так до бесконечности...

как понять какая библиотека ругается или как починить?
2. swenzik 16.05.23 14:22 Сейчас в теме
Соединение = Новый COMОбъект("V83.COMConnector");   
Агент=Соединение.ConnectAgent("localhost:1540");
Кластеры = Агент.GetClusters();
Кластер = Кластеры.GetValue(0);
Агент.Authenticate(Кластер,"","");
РабочиеПроцессы  = Агент.GetWorkingProcesses(Кластер);
РабочиеСерверы =  Агент.GetWorkingServers(Кластер);
РабочийСервер=РабочиеСерверы.GetValue(0);
//МассивСессий = Агент.GetSessions(Кластер).Выгрузить();

ОбщийРасходПамяти=0;
МаксимальныйПроцесс=0;
Для каждого Процесс из РабочиеПроцессы цикл
	ОбщийРасходПамяти=ОбщийРасходПамяти+Процесс.MemorySize;
	Если Процесс.IsEnable тогда
		МаксимальныйПроцесс=МАКС(МаксимальныйПроцесс,Процесс.MemorySize);
	КонецЕсли;
КонецЦикла;

Если МаксимальныйПроцесс>1024*1024*30 тогда
	РабочийСервер.TemporaryAllowedProcessesTotalMemory  = ОбщийРасходПамяти*1024;
	Агент.UpdateWorkingServer(Кластер,РабочийСервер);
	ЗапуститьПриложение("Timeout /T 5 /NoBreak",,Истина);
	РабочийСервер.TemporaryAllowedProcessesTotalMemory  = 0;
	Агент.UpdateWorkingServer(Кластер,РабочийСервер);
КонецЕсли;
Показать
3. swenzik 16.05.23 15:42 Сейчас в теме
и кстати TemporaryAllowedProcessesTotalMemory не режет рпхосты, якобы оно что-то помечает непроизводительным и перестаёт навешивать новые соединения. а вот при превышении CriticalProcessesTotalMemory оно выбирает из всех рпхостов самый жирный и прибивает его. так что в предыдущем комментарии надо поменять две строки кода
4. ybatiaev 59 20.12.23 15:24 Сейчас в теме
(3) Доброго дня! Поменять какие строчки? Можете текст итоговый тут разместить?
Заранее спасибо!
5. vano6666 05.07.25 12:57 Сейчас в теме
Приветствую, очень большое спасибо за Ваше решение !

Сильно выручает )

На одном из кластеров ( на версии платформы 8.3.27.1606) начали ловить такую ошибку

[2025-07-05 08:32:56] Start to reset working processes on working server srv1c-03 ...
[2025-07-05 08:32:56] Current memory limit = 0 Kb, current time limit = 300 seconds.
[2025-07-05 08:32:57] New memory limit = 1887814 Kb, new time limit = 1 second.
[2025-07-05 08:32:57] Waiting 10 seconds for the new settings to take effect ...
[2025-07-05 08:33:07] Restored memory limit = 0 Kb, restored time limit = 300 seconds.
[2025-07-05 08:33:07] Reset of working processes on working server srv1c-03 is finished.
[2025-07-05 08:33:07] Inspection of cluster [srv1c-03+srv1c-01] on tcp://srv1c-03:1540 is finished.
[2025-07-05 08:38:07] Retrieving the COM class factory for component with CLSID {181E893D-73A4-4722-B61D-D604B3D67D47} failed due to the following error: 8000401a Процесс сервера не может быть запущен, так как указана неправильная идентификация. Проверьте правильность указания имени пользователя и пароля. (0x8000401A).
[2025-07-05 08:43:07] Retrieving the COM class factory for component with CLSID {181E893D-73A4-4722-B61D-D604B3D67D47} failed due to the following error: 8000401a Процесс сервера не может быть запущен, так как указана неправильная идентификация. Проверьте правильность указания имени пользователя и пароля. (0x8000401A).
[2025-07-05 08:48:07] Retrieving the COM class factory for component with CLSID {181E893D-73A4-4722-B61D-D604B3D67D47} failed due to the following error: 8000401a Процесс сервера не может быть запущен, так как указана неправильная идентификация. Проверьте правильность указания имени пользователя и пароля. (0x8000401A).
[2025-07-05 08:53:07] Retrieving the COM class factory for component with CLSID {181E893D-73A4-4722-B61D-D604B3D67D47} failed due to the following error: 8000401a Процесс сервера не может быть запущен, так как указана неправильная идентификация. Проверьте правильность указания имени пользователя и пароля. (0x8000401A).
[2025-07-05 08:58:07] Retrieving the COM class factory for component with CLSID {181E893D-73A4-4722-B61D-D604B3D67D47} failed due to the following error: 8000401a Процесс сервера не может быть запущен, так как указана неправильная идентификация. Проверьте правильность указания имени пользователя и пароля. (0x8000401A).

[2025-07-05 09:03:07] V83.COMConnector initialized successfully.
[2025-07-05 09:03:07] Connecting tcp://srv1c-03:1540 ...
[2025-07-05 09:03:07] Connected tcp://srv1c-03:1540 successfully.
[2025-07-05 09:03:07] Inspecting cluster [srv1c-03+srv1c-01] on tcp://srv1c-03:1540 ...
[2025-07-05 09:03:07] Authenticating with [srv1c-03+srv1c-01] ...
[2025-07-05 09:03:07] Authenticated with [srv1c-03+srv1c-01] successfully. [2025-07-05 09:03:07] srv1c-03, PID 36680 (15204332 Kb) exceeds memory limit of 10485760 Kb. [2025-07-05 09:03:07] List of working servers to be reset: srv1c-03

кручу верчу - уже перелопатил много чего - не могу понять

успешно работало до версии платформы 8.3.24 - потом что то произошло и начал валить вот такие ошибки

причем иногда как в примере. - 4-5 вывалит потом вроде как дальше работает

а иногда подряд, прям подряд дает ошибку и все. - помогает перезапуск - после перезапуска какое то время работает

1-2 часа - потом повторяется

Вопрос : не сталкивались ? возможно решали эту проблему ?
Оставьте свое сообщение