Áú»¢¶Ä²©

Esta es una traducci¨®n de la p¨¢gina de documentaci¨®n original en espa?ol. Ay¨²danos a mejorarla.

15 Creaci¨®n de nombres de contadores de rendimiento personalizados para VMware

Descripci¨®n general

La ruta del contador de rendimiento de VMware tiene el formato grupo/contador[rollup] donde:

  • grupo: el grupo de contadores de rendimiento, por ejemplo cpu
  • contador: el nombre del contador de rendimiento, por ejemplo usagemhz
  • rollup: el tipo de resumen del contador de rendimiento, por ejemplo average

De modo que, para el ejemplo anterior dar¨ªa la siguiente ruta del contador: cpu/usagemhz[average]

Las descripciones del grupo de contadores de rendimiento, los nombres de los contadores y los tipos se pueden encontrar en la .

Es posible obtener nombres internos y crear nombres de contadores de rendimiento personalizados utilizando m¨¦tricas de script en Áú»¢¶Ä²©.

°ä´Ç²Ô´Ú¾±²µ³Ü°ù²¹³¦¾±¨®²Ô

  1. Cree una m¨¦trica de secuencia de comandos deshabilitada en el equipo principal de VMware (donde est¨¢ presente la m¨¦trica eventlog[]) con los siguientes par¨¢metros:

  • Nombre: m¨¦tricas de VMware
  • Tipo: Gui¨®n
  • Clave: vmware.metrics
  • Tipo de informaci¨®n: Texto
  • Script: copie y pegue el script proporcionado a continuaci¨®n
  • Tiempo de espera: 10
  • Historial: No almacenar
  • Habilitado: sin marcar

Script

try {
           Áú»¢¶Ä²©.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();
           }
           Áú»¢¶Ä²©.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) {
           Áú»¢¶Ä²©.log(4, 'vmware call failed : '+error);
           result = {};
       }
       
       return result;

Una vez que el elemento est¨¦ configurado, presione el bot¨®n Probar, luego presione Obtener valor.

Copie el XML recibido a cualquier formateador XML y busque la m¨¦trica deseada.

Un ejemplo de XML para una m¨¦trica:

<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>

Utilice XPath para extraer la ruta del contador del XML recibido. Para el ejemplo anterior, el XPath ser¨¢:

campo xPath valor
grupo //groupInfo[../key=6]/key CPU
contador //nameInfo[../key=6]/key usagemhz
rollup //rollupType[../key=6] promedio

La ruta del contador de rendimiento resultante en este caso es: cpu/usagemhz[average]