Zabbix: Мониторинг рабочих процессов

07.02.20

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

Мониторинг памяти, потребляемой рабочими процессами, средствами Zabbix. Создание пользовательских LLD правил с помощью One Script

Файлы

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

Наименование Скачано Купить файл
Zabbix: Мониторинг рабочих процессов: МониторингПамятиРабочихПроцессов.epf
.epf 8,30Kb
5 2 500 руб. Купить
Zabbix: Мониторинг рабочих процессов: RphostPID.os
.os 4,47Kb
5 2 500 руб. Купить

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

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

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

В этой статье описан один из способов мониторинга памяти, потребляемой рабочими процессами rphost средстами Zabbix.

Кратко механизм мониторинга можно описать следующим образом:

1. На стороне 1С по расписанию запускается обработка, которая подключается к кластеру серверов и получает от него необходимые данные

2. Полученные данные отправляются на сервер Zabbix с помощью механизма Zabbix sender

3. Количество рабочих процессов на сервере 1С не постоянно. Для того, тобы Zabbix сервер хранил и анализировал данные в разрезе отдельных процессов, должно быть настроено динамическое обнаружение рабочих процессов

4. Динамическое обнаружение можно реализовать путем создания пользовательских LLD (Low Level Discovery) правил на стороне Zabbix сервера

5. Данный механизм предполагает выполнение скрипта, осуществляющего обнаружение рабочих процессов на Zabbix агенте

Таким образом, настройку мониторинга рабочих процессов можно разделить на следующие этапы:

1. Настройка сбора и отправки данных

2. Настройка Zabbix агента для реализации механизма динамического обнаружения рабочих процессов

3. Настройка Zabbix сервера для получения, хранения и анализа данных

1. Настройка сбора и отправки данных

Сбор данных для мониторинга можно реализовать с помощью внешней обработки, настроенной на запуск по расписанию, либо регламентного задания. Пример кода с использованием COM соединения:

Процедура ВыполнитьКоманду(ИдентификаторКоманды) Экспорт

	Если ИдентификаторКоманды = "МониторингПамятиРабочихПроцессов" Тогда
		СтруктураПараметров = Новый Структура; // Указываются настройки подключения к кластеру:
		СтруктураПараметров.Вставить("АдресКластера", "Server:1540"); 
		СтруктураПараметров.Вставить("ПортКластера", 1541);
		СтруктураПараметров.Вставить("АдминистраторКластера", "Administrator");
		СтруктураПараметров.Вставить("ПарольАдминистратораКластера", "Password");
		
		ПолучитьЗначения(СтруктураПараметров);
	КонецЕсли;
	
КонецПроцедуры

Процедура ПолучитьЗначения(СтруктураПараметров) Экспорт
	
	АдресКластера = СтруктураПараметров.АдресКластера;
	ПортКластера = СтруктураПараметров.ПортКластера;
	АдминистраторКластера = СтруктураПараметров.АдминистраторКластера;
	ПарольАдминистратораКластера = СтруктураПараметров.ПарольАдминистратораКластера;
	
	ПараметрыСоединения = ПроверитьСоединениеСКластером(
	    АдресКластера,
	    ПортКластера, 
	    АдминистраторКластера, 
	    ПарольАдминистратораКластера);
		
	Если ПараметрыСоединения = Неопределено Тогда
		Возврат;
	КонецЕсли;
	
	МенеджерСоединений = ПараметрыСоединения["МенеджерСоединений"];
	СоединениеСЦентральнымСервером = ПараметрыСоединения["СоединениеСЦентральнымСервером"];
	Кластер = ПараметрыСоединения["Кластер"];
	
	Процессы = СоединениеСЦентральнымСервером.GetWorkingProcesses(Кластер);                 
	
	Для Каждого Процесс Из Процессы Цикл
		КодВозврата = "";
		ЗапуститьПриложение( // указывается команда отправки данных серверу через zabbix sender. Подробнее о механизме zabbix_sender можно прочитать в документации
			"C:\zabbix_agent\zabbix_sender.exe zabbix_sender -z <IP zabbix сервера> -s ""<наблюдаемый узел Zabbix>"" -k Rphost[" + Процесс.PID + "] -o " + Формат(Процесс.MemorySize, "ЧГ=''"), 
			,
			Истина, 
			КодВозврата);
	КонецЦикла;
	
КонецПроцедуры

Функция ПроверитьСоединениеСКластером(АдресКластера, ПортКластера, Администратор, Пароль) Экспорт
    
    Попытка
		МенеджерСоединений = Новый COMОбъект("V83.COMConnector");
		СоединениеСЦентральнымСервером = МенеджерСоединений.ConnectAgent(АдресКластера);
	Исключение
		ЗаписьЖурналаРегистрации("ПроверитьСоединениеСКластером", УровеньЖурналаРегистрации.Ошибка,,, ПодробноеПредставлениеОшибки(ИнформацияОбОшибке()));
		Возврат Неопределено;
	КонецПопытки;
	
	Попытка
		СписокКластеров = СоединениеСЦентральнымСервером.GetClusters();
	Исключение
		ЗаписьЖурналаРегистрации("ПроверитьСоединениеСКластером", УровеньЖурналаРегистрации.Ошибка, Метаданные.ОбщиеМодули.КонтрольПамятиСервер,, ПодробноеПредставлениеОшибки(ИнформацияОбОшибке()));
		Возврат Неопределено;
	КонецПопытки;
	
	НомерКластера = СписокКластеров.GetLowerBound();
	ПоследнийНомерКластера = СписокКластеров.GetUpperBound();
	Пока НомерКластера <= ПоследнийНомерКластера Цикл
		Кластер = СписокКластеров.GetValue(НомерКластера);
		Если Кластер.MainPort = ПортКластера Тогда
			Прервать;
		КонецЕсли;
		НомерКластера = НомерКластера + 1;
	КонецЦикла;
	
	Если НомерКластера > ПоследнийНомерКластера Тогда
		Текст = "Кластер с портом " + XMLСтрока(ПортКластера) + " не зарегистрирован на центральном сервере " + АдресКластера;		
		Возврат Неопределено;
	КонецЕсли;
	
	Кластер = СписокКластеров.GetValue(НомерКластера);
	
	Попытка
		СоединениеСЦентральнымСервером.Authenticate(Кластер, Администратор, Пароль);
	Исключение
		ЗаписьЖурналаРегистрации("ПроверитьСоединениеСКластером", УровеньЖурналаРегистрации.Ошибка,	Метаданные.ОбщиеМодули.КонтрольПамятиСервер,, ПодробноеПредставлениеОшибки(ИнформацияОбОшибке()));
		Возврат Неопределено;
	КонецПопытки;
	
	Возврат Новый Структура("МенеджерСоединений, СоединениеСЦентральнымСервером, Кластер", МенеджерСоединений, СоединениеСЦентральнымСервером, Кластер);
		
КонецФункции

К статье приложена обработка, использующая данный код. Она может быть подключена к типовым конфигурациям средствами БСП через дополнительные внешние отчеты и обработки и запускаться по расписанию. Обработка протестирована на платформе 8.3.12.1790.

Данные отправляются в цикле отдельно для каждого рабочего процесса. При этом ожидается, что в настройках Zabbix сервера создан элемен элемент под каждое значение с именем Rphost[<PID>] (об этом далее).
 

2. Настройка Zabbix агента для реализации механизма динамического обнаружения рабочих процессов

Создание правил обнаружения применяется в том случае, когда на этапе создания элемента данных Zabbix не известны его параметры. В данном случае мы не знаем количество и PID рабочих процессов, которые требуется мониторить.

Настройка обнаружения на стороне Zabbix агента заключается в следующем:

1. В конфигурации агента используется директива UserParameter. Она является инструментом расширения функциональности агента. UserParameter используется для запуска агентом пользовательских скриптов т.е. директива указывает на скрипт. В файл конфигурации zabbix агента zabbix_agentd.conf добавляется строка:

UserParameter=oscript,"C:\Program Files (x86)\OneScript\bin\oscript.exe" C:\temp\RphostPID.os

После обновления файла конфигурации агента необходимо перезапустить.
2. Создается скрипт, который должен возвращать список рабочих процессов в формате JSON следующего вида:

[{"data":[{"{#SERVICE_NAME}":"AA"},{"{#SERVICE_NAME}":"HH"}]}]

В данном случае используется скрипт OneScript со следующим кодом:

#Использовать json
#Использовать strings

Функция ПолучитьПараметры()

	СтруктураПараметров = Новый Структура;
	СтруктураПараметров.Вставить("АдресКластера", "Server:1540");
	СтруктураПараметров.Вставить("ПортКластера", 1541);
	СтруктураПараметров.Вставить("АдминистраторКластера", "Administrator");
	СтруктураПараметров.Вставить("ПарольАдминистратораКластера", "Password");
		
	Возврат СтруктураПараметров;
	
КонецФункции

Функция ПолучитьЗначения(СтруктураПараметров)
	
	ПараметрыСоединения = ПроверитьСоединениеСКластером(
	    СтруктураПараметров.АдресКластера,
	    СтруктураПараметров.ПортКластера, 
	    СтруктураПараметров.АдминистраторКластера, 
	    СтруктураПараметров.ПарольАдминистратораКластера);
	
	МенеджерСоединений = ПараметрыСоединения["МенеджерСоединений"];
	СоединениеСЦентральнымСервером = ПараметрыСоединения["СоединениеСЦентральнымСервером"];
	Кластер = ПараметрыСоединения["Кластер"];
	
	Процессы = СоединениеСЦентральнымСервером.GetWorkingProcesses(Кластер);
	ДанныеПроцессов = ДанныеПроцессов(Процессы);
	СтруктураВывода = Новый Структура;
	СтруктураВывода.Вставить("data", ДанныеПроцессов);
	
	ПарсерJSON = Новый ПарсерJSON();
	СтруктураВыводаJSON = ПарсерJSON.ЗаписатьJSON(СтруктураВывода);
	
	СтруктураВыводаJSON = СтрЗаменить(СтруктураВыводаJSON, "PID", "{#PID}");
	
	Возврат СтруктураВыводаJSON;
	
КонецФункции

Функция ПроверитьСоединениеСКластером(АдресКластера, ПортКластера, Администратор, Пароль)
    
	МенеджерСоединений = Новый COMОбъект("V83.COMConnector");
	СоединениеСЦентральнымСервером = МенеджерСоединений.ConnectAgent(АдресКластера);
	СписокКластеров = СоединениеСЦентральнымСервером.GetClusters();

	Для НомерКластера = 0 По СписокКластеров.Count() Цикл
		Кластер = СписокКластеров[НомерКластера];
		Если Кластер.MainPort = ПортКластера Тогда
			Прервать;
		КонецЕсли;
	КонецЦикла;

	СоединениеСЦентральнымСервером.Authenticate(Кластер, Администратор, Пароль);

	Возврат Новый Структура("МенеджерСоединений, СоединениеСЦентральнымСервером, Кластер", МенеджерСоединений, СоединениеСЦентральнымСервером, Кластер);
		
КонецФункции

Функция ДанныеПроцессов(Процессы) 
	
	ТаблицаДанныхПроцессов = Новый ТаблицаЗначений;
	ТаблицаДанныхПроцессов.Колонки.Добавить("PID",, "{#PID}");
	
	Для НомерПроцесса = 0 По Процессы.Count() - 1 Цикл
			
		НоваяСтрока = ТаблицаДанныхПроцессов.Добавить();
			
		Процесс = Процессы[НомерПроцесса];
		НоваяСтрока["PID"] = Процесс.PID;
			
	КонецЦикла;
	
	Возврат ТаблицаДанныхПроцессов;
	
КонецФункции

ПараметрыПодключения = ПолучитьПараметры();
PIDПроцессов = ПолучитьЗначения(ПараметрыПодключения);
Message(PIDПроцессов);

Если на агенте все настроено правильно, то выполнение команды на сервере

zabbix_get -s <имя хоста> -p <порт хоста> -k 'oscript'
будет возвращать данные в требуемом формате.

3. Настройка Zabbix сервера

На стороне сервера необходимо выполнить следующие настройки:

1. Создать шаблон:  «Настройка → Шаблоны → Создать шаблон». Здесь необходимо заполнить только имя

2. Для созданного шаблона создать правило обнаружения: «Настройка → Шаблоны → Имя созданного шаблона → Правила обнаружения → Создать правило обнаружения».

Здесь необходимо заполнить параметры:

Тип: Zabbix agent

Ключ: oscript (имя UserParameter из конфигурации zabbix агента)

3. Создать прототип данных «Настройка → Шаблоны → Имя созданного шаблона → Правила обнаружения → Имя созданного правила → Прототипы элементов данных → Создать прототип элементов данных»

Здесь необходимо заполнить параметры:

Тип: Zabbix trapper

Ключ: Rphost[{#PID}]

Тип информации: числовой (целое положительное)

Тип данных: десятичный

4. Созданный шаблон применить к объекту мониторинга

Через некоторое время будут автоматически созданы элементы мониторинга Rphost[<PID>], соответствующие рабочим процессам. Собранные данные можно анализировать с помощью графиков и настраивать оповещения с помощью триггеров.

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

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

29280 руб.

27.03.2025    68618    41    29    

54

Перенос данных 1C Мониторинг Программист 1С 8.3 1С:Документооборот 1С:ERP Управление предприятием 2 Россия Абонемент ($m)

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

1 стартмани

29.01.2026    196    0    Triplexx    0    

2

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

Описания проблем и решений при настройке мониторинга. Мои подготовительные мероприятия.

23.01.2026    421    ImHunter    5    

1

Технологический журнал Мониторинг Системный администратор Программист Бесплатно (free)

В логах содержится огромное количество полезной информации о том, как «живет» система: какие процессы в ней выполняются, и какие ошибки возникают. Расскажем о том, как выстроить централизованное хранение и обработку разрозненных логов, превратив их в полезный инструмент анализа и диагностики.

29.12.2025    6128    leongl    0    

18

HighLoad оптимизация Мониторинг Системный администратор Программист Бесплатно (free)

Делимся опытом поддержки баз 1С с более чем 6 000 одновременно работающих пользователей и рассказываем о ключевых подходах к контролю высоконагруженных систем. Рассмотрим реальные кейсы и дадим ответ на вопрос о том,: что точно надо контролировать. Сравним ElasticSearch и ClickHouse, дадим ссылки на статьи и репозитарии для быстрого старта, а также посмотрим на примеры рабочих столов для анализа логов технологического журнала в ElasticSearch.

19.12.2025    1665    Sergey.Noskov    2    

11

Администрирование СУБД Технологический журнал Мониторинг Системный администратор Программист Бесплатно (free)

Рассказываем, почему высоконагруженным бэкендам на 1С нужен регулярный мониторинг и что происходит, когда его нет: производительность и стабильность деградируют, а обращения пользователей копятся. Показываем, как построили легкую систему наблюдаемости для бэкендов корпоративных порталов. Она включает сбор метрик из технологического журнала, Apdex, журнала регистрации и динамики размеров таблиц с последующим анализом в связке ClickHouse и служебной информационной базы на 1С. Объясняем, какие отчеты и метрики быстрее всего помогают находить критичные проблемы производительности, и демонстрируем интерфейс расследования. Разбираем несколько кейсов оптимизации, найденных по итогам мониторинга, включая доработки функционала БСП «управление доступом» и «присоединенные файлы».

15.12.2025    3784    tystik    1    

8

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

Когда речь заходит об инфраструктуре 1С, кажется, что все работает как часы: пользователи выполняют свои задачи, отчеты формируются без сбоев, зарплата начисляется вовремя. Как только начинается замедление базы, фоновые задания начинают зависать, а в службу поддержки поступают жалобы от раздраженных пользователей — ситуация требует вмешательства. Необходимо внедрить базовый мониторинг 1С, чтобы избежать неприятных моментов и минимизировать простой системы. Правильно организованный мониторинг не только помогает своевременно выявлять и предотвращать большинство проблем, но и существенно облегчает диагностику в случае сбоев. При этом не требуется больших затрат или сложных ИТ-решений — базовый и при этом эффективный мониторинг можно реализовать быстро, просто и без лишних сложностей. В статье я расскажу, как организовать такой мониторинг, не изобретая велосипед и используя проверенные практики. Но для начала разберемся, зачем вообще мониторить 1С.

03.12.2025    9687    user798823    2    

4

Мониторинг Журнал регистрации Технологический журнал Системный администратор Программист Бесплатно (free)

Мониторинг в ландшафте 1С помогает не только вовремя выявлять проблемы и повышать SLA, но и укреплять информационную безопасность. Разбираем источники данных, ограничения штатных инструментов и современные практики мониторинга на базе Prometheus, ClickHouse и Grafana. А также рассказываем о коробочном решении «Оркестратор 1С-систем» и планах его развития.

29.10.2025    2039    Sibars    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Дмитрий74Чел 248 17.02.20 13:20 Сейчас в теме
Зачем всё это? Какова цель мониторинга памяти? Ваши процессы съедают всю доступную?
2. Sloth 401 18.02.20 09:38 Сейчас в теме
Круто, что oscript - кроссплатформенность! Печально, что COM - первый пункт вычеркиваем :(

Скорректирую предыдущий вопрос: что дает мониторинг именно в разрезе процессов? Т.е. почему не суммарный объем по всем процессам?
3. EShchavleva 28 18.02.20 11:42 Сейчас в теме
(2) Резко возросшее количество памяти, потребляемой рабочим процессом, часто свидетельствует о наличии проблемы в этом процессе. Оперативное обнаружение проблемы дает возможность принять меры по ее устранению до того, как это отразится на сеансах, которые находятся на этом процессе.
Собранные показатели можно использовать для анализа причин произошедшего. Для удобства анализа планирую расширить доработку, добавив мониторинг показателей сеансов пользователей.
4. Sloth 401 18.02.20 12:43 Сейчас в теме
(3)
Оперативное обнаружение проблемы дает возможность принять меры по ее устранению до того, как это отразится на сеансах, которые находятся на этом процессе.

Какая именно реакция происходит когда зафиксировано событие, что произошел "черезмерный" рост памяти (а черезмерный - это в данном контексте сколько) на процессе таком-то? Эта реакция автоматизирована или осуществляется человеком?
5. EShchavleva 28 18.02.20 18:17 Сейчас в теме
(4) Реакция осуществляется человеком и будет зависеть от проблемы. Например, если одновременно обнаружен пользовательский сеанс, потребляющий большое количество памяти, то реакция будет заключаться в удалении этого сеанса, выяснении того, что в этот момент делал пользователь и оптимизации этого инструмента для дальнейшего использования.
6. Sloth 401 19.02.20 09:23 Сейчас в теме
(5) Подскажите еще: сколько на текущий момент ИБ и общее количество сеансов на "подопытном"?

Совет: поставьте в поле "Units" у элемента данных "Rphost memory size (PID $1)" значение "kB", тогда величина объема памяти будет коректной ;)
7. serezh1a 191 23.05.23 11:07 Сейчас в теме
Вопрос от начинающего меня:

Требуются после привязки к объекту мониторинга какие-то дальнейшие манипуляции на Zabbix?

Все собирает, отправляет, но получить не могу. Отправляю, согласно документации того же Zabbix:(
Для отправки сообщения требуется регистрация/авторизация