mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	git-svn-id: http://www.observium.org/svn/observer/trunk@2141 61d68cd4-352d-0410-923a-c4978735b2b8
		
			
				
	
	
		
			133 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| 
 | |
| # FIXME should do the deletion etc in a common file perhaps? like for the sensors
 | |
| 
 | |
| # Try to discover Libvirt Virtual Machines.
 | |
| 
 | |
| if ($config['enable_libvirt'] == '1' && $device['os'] == "linux" )
 | |
| {
 | |
|   $libvirt_vmlist = array();
 | |
| 
 | |
|   echo("Libvirt VM: ");
 | |
| 
 | |
|   $ssh_ok = 0;
 | |
| 
 | |
|   foreach ($config['libvirt_protocols'] as $method)
 | |
|   {
 | |
|     if (strstr($method,'qemu'))
 | |
|     {
 | |
|       $uri = $method.'://' . $device['hostname'] . '/system';
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|       $uri = $method.'://' . $device['hostname'];
 | |
|     }
 | |
|     
 | |
|     if (strstr($method,'ssh') && !$ssh_ok)
 | |
|     {
 | |
|       # Check if we are using SSH if we can log in without password - without blocking the discovery
 | |
|       # Also automatically add the host key so discovery doesn't block on the yes/no question, and run echo so we don't get stuck in a remote shell ;-)
 | |
|       exec('ssh -o "StrictHostKeyChecking no" -o "PreferredAuthentications publickey" -o "IdentitiesOnly yes" ' . $device['hostname'] . ' echo', $out, $ret);
 | |
|       if ($ret != 255) { $ssh_ok = 1; }
 | |
|     }
 | |
| 
 | |
|     if ($ssh_ok || !strstr($method,'ssh'))	
 | |
|     {
 | |
|       # Fetch virtual machine list
 | |
|       unset($domlist);
 | |
|       exec($config['virsh'] . ' -c '.$uri.' list',$domlist);
 | |
| 
 | |
|       foreach ($domlist as $dom)
 | |
|       {
 | |
|         list($dom_id,) = explode(' ',trim($dom),2);
 | |
| 
 | |
|         if (is_numeric($dom_id))
 | |
|         {
 | |
|           # Fetch the Virtual Machine information.
 | |
|           unset($vm_info_array);
 | |
|           exec($config['virsh'] . ' -c '.$uri.' dumpxml ' . $dom_id,$vm_info_array);
 | |
| 
 | |
|           # <domain type='kvm' id='3'>
 | |
|           #   <name>moo.example.com</name>
 | |
|           #   <uuid>48cf6378-6fd5-4610-0611-63dd4b31cfd6</uuid>
 | |
|           #   <memory>1048576</memory>
 | |
|           #   <currentMemory>1048576</currentMemory>
 | |
|           #   <vcpu>8</vcpu>
 | |
|           #   <os>
 | |
|           #     <type arch='x86_64' machine='pc-0.12'>hvm</type>
 | |
|           #     <boot dev='hd'/>
 | |
|           #   </os>
 | |
|           #   <features>
 | |
|           #     <acpi/>
 | |
|           #   (...)
 | |
| 
 | |
|           # Convert array to string
 | |
|           unset($vm_info_xml);
 | |
|           foreach ($vm_info_array as $line) { $vm_info_xml .= $line; }
 | |
| 
 | |
|           $xml = simplexml_load_string('<?xml version="1.0"?> ' . $vm_info_xml);
 | |
|           if ($debug) { print_r($xml); }
 | |
| 
 | |
|           $vmwVmDisplayName = $xml->name;
 | |
|           $vmwVmGuestOS   = ''; # libvirt does not supply this
 | |
|           $vmwVmMemSize   = $xml->currentMemory / 1024;
 | |
|           exec($config['virsh'] . ' -c '.$uri.' domstate ' . $dom_id,$vm_state);
 | |
|           $vmwVmState = ucfirst($vm_state[0]);
 | |
|           $vmwVmCpus = $xml->vcpu;
 | |
| 
 | |
|           # Check whether the Virtual Machine is already known for this host.
 | |
|           $result = mysql_query("SELECT * FROM vminfo WHERE device_id = '" . $device["device_id"] . "' AND vmwVmVMID = '" . $dom_id . "' AND vm_type='libvirt'");
 | |
|           if (mysql_num_rows($result) == 0)
 | |
|           {
 | |
|             mysql_query("INSERT INTO vminfo (device_id, vm_type, vmwVmVMID, vmwVmDisplayName, vmwVmGuestOS, vmwVmMemSize, vmwVmCpus, vmwVmState) VALUES (" . $device["device_id"] . ", 'libvirt',
 | |
|                 '" . $dom_id . "', '" . mres($vmwVmDisplayName) . "', '" . mres($vmwVmGuestOS) . "', '" . $vmwVmMemSize . "', '" . $vmwVmCpus . "', '" . mres($vmwVmState) . "')");
 | |
|             echo("+");
 | |
|             log_event("Virtual Machine added: $vmwVmDisplayName ($vmwVmMemSize MB)", $device, 'vm', mysql_insert_id());
 | |
|           } else {
 | |
|             $row = mysql_fetch_assoc($result);
 | |
|             if ($row['vmwVmState'] != $vmwVmState
 | |
|              || $row['vmwVmDisplayName'] != $vmwVmDisplayName
 | |
|              || $row['vmwVmCpus'] != $vmwVmCpus
 | |
|              || $row['vmwVmGuestOS'] != $vmwVmGuestOS
 | |
|              || $row['vmwVmMemSize'] != $vmwVmMemSize)
 | |
|             {
 | |
|               mysql_query("UPDATE vminfo SET vmwVmState='" . mres($vmwVmState) . "', vmwVmGuestOS='" . mres($vmwVmGuestOS) . "', vmwVmDisplayName='". mres($vmwVmDisplayName) . "',
 | |
|                   vmwVmMemSize='" . mres($vmwVmMemSize) . "', vmwVmCpus='" . mres($vmwVmCpus) . "' WHERE device_id='" . $device["device_id"] . "' AND vm_type='libvirt' AND vmwVmVMID='" . $dom_id . "'");
 | |
|               echo("U");
 | |
|               # FIXME eventlog
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|               echo(".");
 | |
|             }
 | |
|           }
 | |
| 
 | |
|           # Save the discovered Virtual Machine.
 | |
|           $libvirt_vmlist[] = $dom_id;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     
 | |
|     # If we found VMs, don't cycle the other protocols anymore.
 | |
|     if (count($libvirt_vmlist)) { break; }
 | |
|   }
 | |
| 
 | |
|   # Get a list of all the known Virtual Machines for this host.
 | |
|   $db_vm_list = mysql_query("SELECT id, vmwVmVMID, vmwVmDisplayName FROM vminfo WHERE device_id = '" . $device["device_id"] . "' AND vm_type='libvirt'");
 | |
| 
 | |
|   while ($db_vm = mysql_fetch_assoc($db_vm_list))
 | |
|   {
 | |
|     # Delete the Virtual Machines that are removed from the host.
 | |
| 
 | |
|     if (!in_array($db_vm["vmwVmVMID"], $libvirt_vmlist))
 | |
|     {
 | |
|       mysql_query("DELETE FROM vminfo WHERE id = '" . $db_vm["id"] . "'");
 | |
|       echo("-");
 | |
|       log_event("Virtual Machine removed: " . $db_vm['vmwVmDisplayName'], $device, 'vm', $db_vm['id']);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   echo("\n");
 | |
| }
 | |
| 
 | |
| ?>
 |