IntoducciónLo más importante es que el procesador tenga Virtual Technology, empezamos comprobando si el procesador esta incluido en la 
lista de CPUs que soportan HVM.Verificamos si el procesador soporta el conjunto instrucciones de virtualización compatible con KVM. Buscamos la cadena vmx o svm en los flags del procesador.
cat /proc/cpuinfo | grep vmx # Intel
cat /proc/cpuinfo | grep svm # AMD
deberías obtener un resultado parecido a:
INTEL
flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx lm constant_tsc arch_perfmon pebs bts rep_good pni monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr dca sse4_1 lahf_lm
AMD
flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow rep_goodpni cx16 lahf_lm cmp_legacy svm extapic cr8_legacy 3dnowprefetch
Si no obtenemos la salida, KVM no funcionará.
Revisar que el BIOS de la maquina tenga habilitada la opción de Virtual Technology
Instalar KVM y otros.Activar el repositorio Universe y actualizar el sistema.
sudo su
vim /etc/apt/source.list
[...]
deb http://ar.archive.ubuntu.com/ubuntu/ hardy universe                   
deb-src http://ar.archive.ubuntu.com/ubuntu/ hardy universe
deb http://ar.archive.ubuntu.com/ubuntu/ hardy-updates universe
deb-src http://ar.archive.ubuntu.com/ubuntu/ hardy-updates universe
[...]
aptitude update
aptitude upgrade
aptitude install qemu virt-manager libvirt-bin kvm
Añadimos los usuarios que queremos administren KVM al grupo kvm
adduser  kvm
Reiniciamos el Equipo.
Probamos el comando kvm
kvm
Si aparece el siguiente mensaje, el procesador no soporta instrucciones de virtualización (aun habiendo aprobado el test de flags) o el BIOS tiene deshabilitado la opción de Virtualización.
open /dev/kvm: No such file or directory
Could not initialize KVM, will disable KVM support
Ubuntu does not support running KVM without hardware acceleration. Sorry.
Para ser ordenados creamos un directorio donde alojaremos nuestras maquinas virtuales.
mkdir /home/kvm
chown nobody.nogroup /home/kvm
KVM y Qemu se pueden manejar desde comand line (de ahora en adelante 'CL') o desde un entorno grafico.
Administrar KVM desde CL.Creando un Guest.
aptitude install ubuntu-vm-builder
ubuntu-vm-builder kvm hardy \
                 --domain vmX \
                 --dest /home/kvm/vmX \
                 --arch i386 \
                 --hostname vmX \
                 --mem 256 \
                 --user bgx \
                 --pass elpass \
                 --ip  \
                 --mask  \
                 --net  \
                 --bcast  \
                 --gw  \
                 --dns  \
                 --mirror http://archive.localubuntumirror.net/ubuntu \
                 --components main,universe \
                 --addpkg vim openssh-server molly-guard etckeeper \
                 --libvirt qemu:///system ;
Usar una imagen de CD de la distribucion linux que mas nos guste.
Cambiamos la opción mirror:
mount -o loop path_to_image/imagen.iso /mnt
ubuntu-vm-builder --mirror /mnt
Otras herramientas con las que contamos son python-virtinst (virt-install, virt-clone, virt-viewer).
Ejemplo clonado de guest usando virt-clone.
virt-clone -o vm_origen -n hostname_nuevo --file /home/kvm/nueva_maquina/disco.img
Para visualizar la cantidad de maquinas funcionando, detenerlas, arrancarlas, hacer hot-plug de un dispositivo usb, etc... utilizamos "Virtual Shell".
El comando virsh es parte del paquete libvirt.
Existen multitud de comandos para manipular imagenes con virsh. Para manipular las imagenes con virsh necesitamos ser agregado al grupo libvirtd.
aptitude install libvirt-bin
adduser  libvirtd
virsh
Welcome to virsh, the virtualization interactive terminal.
Type:  'help' for help with commands
      'quit' to quit
virsh # help
Commands:  
   help            print help
   attach-device   attach device from an XML file
   attach-disk     attach disk device           
   attach-interface attach network interface    
   autostart       autostart a domain           
   capabilities    capabilities                 
   connect         (re)connect to hypervisor    
   console         connect to the guest console 
   create          create a domain from an XML file
   start           start a (previously defined) inactive domain
   destroy         destroy a domain                           
   detach-device   detach device from an XML file             
   detach-disk     detach disk device                         
   detach-interface detach network interface                  
   define          define (but don't start) a domain from an XML file
   domid           convert a domain name or UUID to domain id       
   domuuid         convert a domain name or id to domain UUID       
   dominfo         domain information                               
   domname         convert a domain id or UUID to domain name       
   domstate        domain state
   domblkstat      get device block stats for a domain
   domifstat       get network interface stats for a domain
   dumpxml         domain information in XML
   freecell        NUMA free memory
   hostname        print the hypervisor hostname
   list            list domains
   migrate         migrate domain to another host
   net-autostart   autostart a network
   net-create      create a network from an XML file
   net-define      define (but don't start) a network from an XML file
   net-destroy     destroy a network
   net-dumpxml     network information in XML
   net-list        list networks
   net-name        convert a network UUID to network name
   net-start       start a (previously defined) inactive network
   net-undefine    undefine an inactive network
   net-uuid        convert a network name to network UUID
   nodeinfo        node information
   quit            quit this interactive terminal
   reboot          reboot a domain
   restore         restore a domain from a saved state in a file
   resume          resume a domain
   save            save a domain state to a file
   schedinfo       show/set scheduler parameters
   dump            dump the core of a domain to a file for analysis
   shutdown        gracefully shutdown a domain
   setmem          change memory allocation
   setmaxmem       change maximum memory limit
   setvcpus        change number of virtual CPUs
   suspend         suspend a domain
   ttyconsole      tty console
   undefine        undefine an inactive domain
   uri             print the hypervisor canonical URI
   vcpuinfo        domain vcpu information
   vcpupin         control domain vcpu affinity
   version         show version
   vncdisplay      vnc display
Administrar KVM desde GUI a través de SSH.Esta opción es mucho mas intuitiva y "user friendly"
aptitude install virt-manager xauth
Desde una maquina remota con X11 podemos acceder al servidor a través de ssh habilitando la opción de gráficos.
ssh -X server_hostname_o_ip
El resultado será la GUI de Virt-manager en nuestro escritorio, de donde podemos administrar todas las maquina virtuales, crear nuevas y modificar las existentes.

