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

20.01.23

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

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

Скачать исходный код

Наименование Файл Версия Размер
1C RpHost Manager win-x64
.zip 869,09Kb
10
.zip 869,09Kb 10 Скачать
1C RpHost Manager win-x86
.zip 857,75Kb
0
.zip 857,75Kb Скачать

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

См. также

Проблемы на ровном месте, или рассказ о том, как у нас каждое утро стабильно подвисал dev-сервер 1С

Сервера Платформа 1С v8.3 Россия Бесплатно (free)

Меня зовут Павел Белоусов, я работаю Ведущим программистом 1С в компании OCS Distribution. Хочу поделиться историей, как мы столкнулись с постоянными зависаниями dev-сервера 1C, каким образом решили проблему и какие любопытные уроки вынесли из ситуации.

12.04.2024    2075    pbelousov    55    

16

Запуск сервера хранилища конфигураций и сервера удаленного управления на Linux, посредством systemd

Linux Сервера Платформа 1С v8.3 Абонемент ($m)

Сказ о том, как сделать "кошерный" запуск серверов хранилища конфигураций (вдруг еще кто-то до сих пор пользуется) и удаленного администрирования под GNU/Linux с использованием systemd

1 стартмани

07.09.2023    4476    Sloth    0    

23

Первый день архитектора 1С на новой работе

Мониторинг Сервера Администрирование СУБД Бесплатно (free)

Как быстро познакомиться с системой на новой работе или если вас пригласили провести аудит контура на 1С? О том, какие инструменты использовать для быстрой проверки настроек сервера 1С, сервера MS SQL и общей оценки инфраструктуры на производительность, на конференции Infostart Event 2021 Post-Apocalypse рассказал архитектор 1С Юрий Былинкин.

01.06.2023    11015    ardn    19    

82

Путь самурая. Ставим локальный Сервер взаимодействия

Сервера Администрирование веб-серверов Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Подробная пошаговая инструкция (как делал я) установки Сервера взаимодействия версия 22.0.26 на Windows Server 2022. Установка собственного объектного хранилище с помощью системы MinIO (https://min.io/). Настройка Сервера взаимодействия для обмена файлами в сообщениях.

1 стартмани

07.04.2023    13242    VPanin56    42    

75

Быстрое конфигурирование серверов с Ansible

Администрирование веб-серверов Сервера Бесплатно (free)

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

26.01.2023    5184    lopatrik    4    

22

Жизнь платформы 1C:Предприятие в кластере Kubernetes

Сервера DevOps и автоматизация разработки Облачные сервисы, хостинг Бесплатно (free)

Во многих сферах запуск приложений в Kubernetes является де-факто стандартом архитектуры, так как это позволяет быстро и эффективно задействовать ресурсы, не затрачивая на это большие деньги. Но с платформой 1С:Предприятие не все так просто, но потенциально возможно. Руслан Жданов на митапе «DevOps в 1С: CI/CD. Непрерывная интеграция и поставка решений на 1С» рассказал про то, как с помощью Kubernetes организовать в облаке управление кластером из серверов 1С и реализовать там тестирование приложений на 1С или запуск скриптов на OneScript.

24.01.2023    9716    ZhdanovR    3    

27

Замена имени сервера в файле ibases.v8i у пользователей в домене через GPO

Сети Сервера Платформа 1С v8.3 Абонемент ($m)

При переезде на новый сервер 1С возникла необходимость подготовить всех пользователей (а их 300+) к этому переезду и желательно не мешая их работе. А если быть точнее, то заменить в их списках информационных баз имя сервера. Итак, что имеем в условии.  Есть сервер 1С с именем  WIN2016.  Необходимо перенастроить всех пользователей на новый сервер с именем SRV1C. Для этого придется либо руками у каждого пользователя исправить записи по каждой базе через открытие 1С, либо поправить файл ibases.v8i, который находится в папке профиля пользователя. Второй вариант более интересен, но лезть на 300+ компьютеров не наш метод.

1 стартмани

30.11.2022    3264    1    dungeonkeeper    13    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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(Кластер,РабочийСервер);
КонецЕсли;
Показать
smit1c; +1
3. swenzik 16.05.23 15:42 Сейчас в теме
и кстати TemporaryAllowedProcessesTotalMemory не режет рпхосты, якобы оно что-то помечает непроизводительным и перестаёт навешивать новые соединения. а вот при превышении CriticalProcessesTotalMemory оно выбирает из всех рпхостов самый жирный и прибивает его. так что в предыдущем комментарии надо поменять две строки кода
+
4. ybatiaev 58 20.12.23 15:24 Сейчас в теме
(3) Доброго дня! Поменять какие строчки? Можете текст итоговый тут разместить?
Заранее спасибо!
+
Оставьте свое сообщение