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

20.01.23

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

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
1C RpHost Manager win-x64
.zip 869,09Kb
12
12 Скачать (10 SM) Купить за 4 550 руб.
1C RpHost Manager win-x86
.zip 857,75Kb
0
0 Скачать (10 SM) Купить за 4 550 руб.

Исходный код разработки на 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

См. также

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

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

1 стартмани

08.11.2024    1080    12    gortrex    2    

3

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

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

31.10.2024    1852    capitan    0    

0

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

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

31.10.2024    11225    a.doroshkevich    22    

73

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

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

29.10.2024    3212    jul.dolganova    8    

18

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

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

18.10.2024    2639    capitan    6    

13

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

Основные критерии, на которые необходимо обратить внимание.

31.07.2024    2672    EFSOL_oblako    2    

1
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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) Доброго дня! Поменять какие строчки? Можете текст итоговый тут разместить?
Заранее спасибо!
Оставьте свое сообщение