16. Создание пользовательских имен счётчиков производительности для VMware

Обзор

Путь счётчика производительности VMware имеет формат group/counter[rollup], где:

  • group — группа счётчика производительности, например: cpu
  • counter — имя счётчика производительности, например: usagemhz
  • rollup — тип свёртки счётчика производительности, например: average

Таким образом, вышеприведённый пример мог бы дать следующий путь счётчика: cpu/usagemhz[average]

Описания групп счётчиков производительности, имена счётчиков и типы свёртки можно найти в документации VMware [en].

Получить внутренние имена и создать пользовательские имена счётчиков производительности в Zabbix можно, используя скриптовый элемент данных.

Настройка

  1. На основном узле сети VMware (где присутствует элемент данных eventlog[]) создайте деактивированный скриптовый элемент данных со следующими параметрами:

  • Имя: VMware metrics
  • Тип: Скрипт
  • Ключ: vmware.metrics
  • Тип информациии: Текст
  • Скрипт: перекопируйте и вставьте скрипт, предоставленный ниже
  • Время ожидания: 10
  • Период хранения истории: Не хранить историю
  • Активировано: не отмечено

Скрипт

try {
           Zabbix.log(4, 'vmware metrics script');
       
           var result, resp,
           req = new HttpRequest();
           req.addHeader('Content-Type: application/xml');
           req.addHeader('SOAPAction: "urn:vim25/6.0"');
       
           login = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:urn="urn:vim25">\
           <soapenv:Header/>\
           <soapenv:Body>\
               <urn:Login>\
                   <urn:_this type="SessionManager">SessionManager</urn:_this>\
                   <urn:userName>{$VMWARE.USERNAME}</urn:userName>\
                   <urn:password>{$VMWARE.PASSWORD}</urn:password>\
               </urn:Login>\
           </soapenv:Body>\
       </soapenv:Envelope>'
           resp = req.post("{$VMWARE.URL}", login);
           if (req.getStatus() != 200) {
               throw 'Response code: '+req.getStatus();
           }
       
           query = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:urn="urn:vim25">\
       <soapenv:Header/>\
           <soapenv:Body>\
               <urn:RetrieveProperties>\
                   <urn:_this type="PropertyCollector">propertyCollector</urn:_this>\
                   <urn:specSet>\
                       <urn:propSet>\
                          <urn:type>PerformanceManager</urn:type>\
                          <urn:pathSet>perfCounter</urn:pathSet>\
                       </urn:propSet>\
                       <urn:objectSet>\
                          <urn:obj type="PerformanceManager">PerfMgr</urn:obj>\
                       </urn:objectSet>\
                   </urn:specSet>\
               </urn:RetrieveProperties>\
           </soapenv:Body>\
       </soapenv:Envelope>'
           resp = req.post("{$VMWARE.URL}", query);
           if (req.getStatus() != 200) {
               throw 'Response code: '+req.getStatus();
           }
           Zabbix.log(4, 'vmware metrics=' + resp);
           result = resp;
       
           logout = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:urn="urn:vim25">\
           <soapenv:Header/>\
           <soapenv:Body>\
               <urn:Logout>\
                   <urn:_this type="SessionManager">SessionManager</urn:_this>\
               </urn:Logout>\
           </soapenv:Body>\
       </soapenv:Envelope>'
       
           resp = req.post("{$VMWARE.URL}",logout);         
           if (req.getStatus() != 200) {
               throw 'Response code: '+req.getStatus();
           }
       
       } catch (error) {
           Zabbix.log(4, 'vmware call failed : '+error);
           result = {};
       }
       
       return result;

После настройки элемента данных нажмите кнопку Тест, затем нажмите Получить значение.

Скопируйте полученный XML в любой форматировщик XML и найдите нужную метрику.

Пример XML для одной метрики:

<PerfCounterInfo xsi:type="PerfCounterInfo">
           <key>6</key>
           <nameInfo>
               <label>Usage in MHz</label>
               <summary>CPU usage in megahertz during the interval</summary>
               <key>usagemhz</key>
           </nameInfo>
           <groupInfo>
               <label>CPU</label>
               <summary>CPU</summary>
               <key>cpu</key>
           </groupInfo>
           <unitInfo>
               <label>MHz</label>
               <summary>Megahertz</summary>
               <key>megaHertz</key>
           </unitInfo>
           <rollupType>average</rollupType>
           <statsType>rate</statsType>
           <level>1</level>
           <perDeviceLevel>3</perDeviceLevel>
       </PerfCounterInfo>

Используйте XPath, чтобы извлечь путь счётчика из полученного XML. Для вышеприведённого примера, XPath будет:

поле xPath значение
group //groupInfo[../key=6]/key cpu
counter //nameInfo[../key=6]/key usagemhz
rollup //rollupType[../key=6] average

Итоговый путь счётчика производительности в данном случае получается: cpu/usagemhz[average]