Áú»¢¶Ä²©

This is a translation of the original English documentation page. Help us make it better.

16 Cr¨¦ation de noms de compteurs de performances personnalis¨¦s pour VMware

Aper?u

Le chemin du compteur de performances VMware a le format group/counter[rollup] o¨´ :

  • group - tle groupe de compteurs de performance, par exemple cpu
  • counter - le nom du compteur de performance, par exemple usagemhz
  • rollup - le type de cumul du compteur de performances, par exemple moyenne

Ainsi, l'exemple ci-dessus donnerait le chemin de compteur suivant : cpu/usagemhz[average]

Les descriptions des groupes de compteurs de performance, les noms des compteurs et les types de cumul peuvent ¨ºtre trouv¨¦s dans la [documentation VMware] (https://developer.vmware.com/apis/968).

Il est possible d'obtenir des noms internes et de cr¨¦er des noms de compteurs de performance personnalis¨¦s en utilisant un ¨¦l¨¦ment de script dans Áú»¢¶Ä²©.

Configuration

  1. Cr¨¦ez un ¨¦l¨¦ment de script d¨¦sactiv¨¦ sur l'h?te VMware principal (o¨´ l'¨¦l¨¦ment eventlog[] est pr¨¦sent) avec les param¨¨tres suivants?:

  • Nom?: m¨¦triques VMware
  • Type : Script
  • °ä±ô¨¦?: vmware.metrics
  • Type d'information : Texte
  • Script?: copiez et collez le script fourni ci-dessous
  • Expiration?: 10
  • P¨¦riode de stockage de l'historique?: Ne gardez pas l'historique
  • ´¡³¦³Ù¾±±¹¨¦?: non coch¨¦

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;

Une fois l'¨¦l¨¦ment configur¨¦, appuyez sur le bouton Test, puis appuyez sur Obtenir la valeur.

Copiez le XML re?u dans n'importe quel formateur XML et trouvez la m¨¦trique souhait¨¦e.

Exemple de XML pour une m¨¦trique?:

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

Utilisez XPath pour extraire le chemin du compteur du XML re?u. Pour l'exemple ci-dessus, le XPath sera?:

champ xPath valeur
group //groupInfo[../key=6]/key cpu
counter //nameInfo[../key=6]/key usagemhz
rollup //rollupType[../key=6] average

Le chemin du compteur de performances r¨¦sultant dans ce cas est?: cpu/usagemhz[average]