[comment]: # translation:outdated

[comment]: # ({2ff5f110-e03ef403})
# 15. Создание пользовательских имён счётчиков производительности для VMware

[comment]: # ({/2ff5f110-e03ef403})

[comment]: # ({24b7e9a0-eaab320d})
### Обзор

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

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

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

Описания групп счётчиков производительности, имена счётчиков и типы свёртки
можно найти в [документации VMware
\[en\]](https://developer.broadcom.com/xapis/vsphere-web-services-api/latest/).

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

[comment]: # ({/24b7e9a0-eaab320d})

[comment]: # ({99add2e1-2d867bd9})

### Настройка

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

![](../../../../assets/en/manual/appendix/items/perf_counter_item.png)

- *Имя (Name)*:  VMware metrics
- *Тип (Type)*: Скрипт (Script)
- *Ключ (Key)*: vmware.metrics
- *Тип информациии (Type of information)*: Текст (Text)
- *Скрипт (Script)*: перекопируйте и вставьте [скрипт](#скрипт), предоставленный ниже
- *Время ожидания (Timeout)*: 10
- *История (History)*: Не хранить (Do not store)
- *Активировано (Enabled)*: не отмечено

#### Скрипт

    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;


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

![](../../../../assets/en/manual/appendix/items/perf_counter_item1.png){width=600}

Скопируйте полученный 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]`

[comment]: # ({/99add2e1-2d867bd9})
