Virtualización · 6 min read · Dec 26, 2025

VBoxHeadless - Ejecutando Máquinas Virtuales Con VirtualBox 4.1 En Un Servidor CentOS 6.2 Sin Interfaz Gráfica

VBoxHeadless - Ejecutando Máquinas Virtuales Con VirtualBox 4.1 En Un Servidor CentOS 6.2 Sin Interfaz Gráfica

Versión 1.0
Autor: Falko Timme
Sígueme en Twitter

Esta guía explica cómo puedes ejecutar máquinas virtuales con VirtualBox 4.1 en un servidor CentOS 6.2 sin interfaz gráfica. Normalmente, utilizas la GUI de VirtualBox para gestionar tus máquinas virtuales, pero un servidor no tiene un entorno de escritorio. Afortunadamente, VirtualBox viene con una herramienta llamada VBoxHeadless que te permite conectarte a las máquinas virtuales a través de una conexión de escritorio remoto, por lo que no hay necesidad de la GUI de VirtualBox.

¡No emito ninguna garantía de que esto funcione para ti!

1 Nota Preliminar

He probado esto en un servidor CentOS 6.2 (sistema host) con la dirección IP 192.168.0.100 donde estoy conectado como un usuario normal (nombre de usuario admin en este ejemplo) en lugar de como root.

Si solo tienes una cuenta de root, pero no una cuenta de usuario normal, crea una de la siguiente manera (usuario admin, grupo admin)…

… crea una contraseña para el nuevo usuario…

# passwd admin

… y conéctate como ese usuario.

2 Instalando VirtualBox

Para instalar VirtualBox 4.1 en nuestro servidor CentOS 6.2, necesitamos privilegios de root, por lo tanto, ejecutamos

$ su

Luego instalamos las dependencias para VirtualBox 4.1 de la siguiente manera:

# yum groupinstall 'Development Tools'
# yum install SDL kernel-devel kernel-headers dkms

Con el último comando hemos instalado los encabezados del kernel de nuestro kernel actualmente utilizado. Los encabezados se encuentran en el directorio /usr/src/kernels/, pero es probable que su directorio no se llame -, sino que tenga un nombre diferente, de modo que el módulo del kernel de VirtualBox no pueda ser construido más tarde porque no se puede encontrar el directorio de encabezados del kernel esperado. Vamos a corregir eso ahora:

Verifica tu versión del kernel…

# uname -r

[root@server1 ~]# uname -r
2.6.32-220.el6.x86_64
[root@server1 ~]#

Esto significa que debería haber un directorio llamado 2.6.32-220.el6.x86_64 en el directorio /usr/src/kernels/. Ahora podemos verificar esto:

[root@server1 kernels]# ls -l
total 4
drwxr-xr-x 22 root root 4096 Jun 25 17:30 2.6.32-220.23.1.el6.x86_64
[root@server1 kernels]#

Como ves, tengo el directorio 2.6.32-220.23.1.el6.x86_64, pero no 2.6.32-220.el6.x86_64. Por lo tanto, creamos un enlace simbólico llamado 2.6.18-238.el5-x86_64 que apunta a 2.6.18-238.9.1.el5-x86_64:

# ln -s 2.6.32-220.23.1.el6.x86_64 `uname -r`

A continuación, descarga y registra la clave pública rpm de VirtualBox:

Ahora habilitamos el repositorio de VirtualBox CentOS en nuestro sistema:

Ahora podemos simplemente instalar VirtualBox 4.1 de la siguiente manera:

# yum install VirtualBox-4.1

Si la instalación es exitosa, la salida debería terminar de la siguiente manera:

[…]
Ejecutando Transacción
Instalando : VirtualBox-4.1-4.1.18_78361_rhel6-1.x86_64 1/1

Creando grupo ‘vboxusers’. Los usuarios de VM deben ser miembros de ese grupo!

No se encontró ningún módulo precompilado para este kernel – intentando construir uno. Los mensajes
emitidos durante la compilación del módulo se registrarán en /var/log/vbox-install.log.

Deteniendo módulos del kernel de VirtualBox [ OK ]
Desinstalando antiguos módulos del kernel de VirtualBox DKMS [ OK ]
Intentando registrar los módulos del kernel de VirtualBox usando DKMS [ OK ]
Iniciando módulos del kernel de VirtualBox [ OK ]

Instalado:
VirtualBox-4.1.x86_64 0:4.1.18_78361_rhel6-1

¡Completo!
[root@server1 kernels]#

(Si la instalación falla porque no se puede encontrar el directorio de encabezados del kernel correcto, la salida terminará de la siguiente manera:

[…]
Ejecutando Transacción
Instalando : VirtualBox-4.1-4.1.18_78361_rhel6-1.x86_64 1/1

Creando grupo ‘vboxusers’. Los usuarios de VM deben ser miembros de ese grupo!

No se encontró ningún módulo precompilado para este kernel – intentando construir uno. Los mensajes
emitidos durante la compilación del módulo se registrarán en /var/log/vbox-install.log.

Deteniendo módulos del kernel de VirtualBox [ OK ]
Desinstalando antiguos módulos del kernel de VirtualBox DKMS [ OK ]
Intentando registrar los módulos del kernel de VirtualBox usando DKMS
Error! No se puede encontrar tu fuente del kernel para el kernel 2.6.32-220.el6.x86_64 en
/lib/modules/2.6.32-220.el6.x86_64/build o /lib/modules/2.6.32-220.el6.x86_64/source.
[FAILED]
(Fallido, intentando sin DKMS)
Recompilando módulos del kernel de VirtualBox [FAILED]
(Mira /var/log/vbox-install.log para averiguar qué salió mal)

Instalado:
VirtualBox-4.1.x86_64 0:4.1.18_78361_rhel6-1

¡Completo!
[root@server1 kernels]#

En este caso, intenta crear el enlace simbólico del kernel correcto (como se mostró antes) y luego ejecuta

# /etc/init.d/vboxdrv setup

para crear el módulo del kernel de VirtualBox.)

Ahora debemos agregar al usuario que ejecutará VirtualBox (admin en este ejemplo) al grupo vboxusers:

# /usr/sbin/usermod -G vboxusers admin

VirtualBox ahora está instalado y listo para ser utilizado.

A partir de la versión 4.0, VirtualBox ha introducido lo que se llaman “paquetes de extensión” y ha externalizado algunas funcionalidades como el soporte de conexión de escritorio remoto (VRDP) que formaba parte de los paquetes de VirtualBox antes de la versión 4.0 en estos paquetes de extensión. Debido a que necesitamos conexiones de escritorio remoto para controlar nuestras máquinas virtuales, necesitamos instalar el paquete de extensión apropiado ahora. Ve a http://www.virtualbox.org/wiki/Downloads, y encontrarás un enlace al siguiente paquete de extensión:

VirtualBox 4.1.18 Oracle VM VirtualBox Extension Pack
Soporte para dispositivos USB 2.0, VirtualBox RDP y arranque PXE para tarjetas Intel.

Descarga e instala el paquete de extensión de la siguiente manera:

(Asegúrate de obtener la última versión del sitio web de VirtualBox.)

Escribe

# exit

para salir de la cuenta de root y convertirte en un usuario normal (admin) nuevamente.

3 Usando VirtualBox En La Línea De Comandos

3.1 Creando Una VM

Para crear una VM en la línea de comandos, podemos usar el comando VBoxManage. Consulta

$ VBoxManage --help

para una lista de opciones disponibles y (¡muy recomendado!) echa un vistazo a http://www.virtualbox.org/manual/ch08.html.

Ahora crearé una VM de Ubuntu 12.04 Server con 1024MB de memoria y un disco duro de 10GB a partir de la imagen iso de Ubuntu 12.04 Server (que he almacenado en /home/ubuntu-12.04-server-amd64.iso):

$ VBoxManage createvm –name “Ubuntu 12.04 Server” –register
$ VBoxManage modifyvm “Ubuntu 12.04 Server” –memory 1024 –acpi on –boot1 dvd –nic1 bridged –bridgeadapter1 eth0
$ VBoxManage createhd –filename Ubuntu_12_04_Server.vdi –size 10000
$ VBoxManage storagectl “Ubuntu 12.04 Server” –name “IDE Controller” –add ide
$ VBoxManage storageattach “Ubuntu 12.04 Server” –storagectl “IDE Controller” –port 0 –device 0 –type hdd –medium Ubuntu_12_04_Server.vdi
$ VBoxManage storageattach “Ubuntu 12.04 Server” –storagectl “IDE Controller” –port 1 –device 0 –type dvddrive –medium /home/ubuntu-12.04-server-amd64.iso

3.2 Importando Una VM Existente

Supongamos que tienes una VM llamada examplevm que deseas reutilizar en este host. En el antiguo host, deberías tener un directorio Machines/examplevm en el directorio de VirtualBox; Machines/examplevm debería contener el archivo examplevm.xml. Copia el directorio examplevm (incluyendo el archivo examplevm.xml) a tu nuevo directorio Machines (si tu nombre de usuario es admin, este es /home/admin/.VirtualBox/Machines - el resultado debería ser /home/admin/.VirtualBox/Machines/examplevm/examplevm.xml).

Además de eso, copia el archivo examplevm.vdi del antiguo directorio VDI al nuevo (por ejemplo, /home/admin/.VirtualBox/VDI/examplevm.vdi).

Después, debes registrar la VM importada:

$ VBoxManage registervm Machines/examplevm/examplevm.xml

3.3 Iniciando Una VM Con VBoxHeadless

Independientemente de si creas una nueva VM o importas una antigua, puedes iniciarla con el comando:

$ VBoxHeadless --startvm "Ubuntu 12.04 Server"

(Reemplaza Ubuntu 12.04 Server con el nombre de tu VM.)

VBoxHeadless iniciará la VM y un servidor VRDP (Protocolo de Escritorio Remoto de VirtualBox) que te permite ver la salida de la VM de forma remota en otra máquina.

Para detener una VM, ejecuta

 $ VBoxManage controlvm "Ubuntu 12.04 Server" poweroff

Para pausar una VM, ejecuta

$ VBoxManage controlvm "Ubuntu 12.04 Server" pause

Para reiniciar una VM, ejecuta

$ VBoxManage controlvm "Ubuntu 12.04 Server" reset

Para aprender más sobre VBoxHeadless, echa un vistazo a

$ VBoxHeadless --help

y en http://www.virtualbox.org/manual/ch07.html#vboxheadless.

Share: X/Twitter LinkedIn

Recibe nuevas publicaciones en tu bandeja de entrada.

No spam. Cancela la suscripción en cualquier momento.