Virtualización · 5 min read · Dec 01, 2025

VBoxHeadless - Ejecutando Máquinas Virtuales Con VirtualBox 4.2 En Un Servidor OpenSUSE 12.2 Sin Interfaz Gráfica

VBoxHeadless - Ejecutando Máquinas Virtuales Con VirtualBox 4.2 En Un Servidor OpenSUSE 12.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.2 en un servidor OpenSUSE 12.2 sin interfaz gráfica. Normalmente, usas 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 OpenSUSE 12.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)…

# groupadd admin  
# useradd -d /home/admin -m -g admin -s /bin/bash admin

… crea una contraseña para el nuevo usuario…

# passwd admin

… y conéctate como ese usuario.

2 Instalando VirtualBox

Para instalar VirtualBox 4.2 en nuestro servidor OpenSUSE 12.2, necesitamos privilegios de root, por lo tanto, ejecutamos

$ su

Primero tenemos que averiguar qué kernel tenemos instalado:

# uname -a
server1:/home/admin # uname -a  
Linux server1 3.4.6-2.10-desktop #1 SMP PREEMPT Thu Jul 26 09:36:26 UTC 2012 (641c197) x86_64 x86_64 x86_64 GNU/Linux  
server1:/home/admin #

Como ves, tengo instalado el paquete kernel-desktop; si tienes instalado el paquete kernel-server, reemplaza desktop por server en el siguiente comando.

Instalamos las dependencias para VirtualBox 4.2 de la siguiente manera (al instalar nuevamente el paquete kernel-desktop / kernel-server, nos aseguramos de que tengamos la última versión instalada):

# zypper install kernel-desktop kernel-desktop-devel kernel-source kernel-syms Xerces-c gcc make

Si el kernel se actualiza, se te indicará que reinicies el sistema; en este caso, ejecuta:

# reboot

Conéctate nuevamente como el usuario normal y luego conviértete en root:

$ su

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

# wget -q http://download.virtualbox.org/virtualbox/debian/oracle_vbox.asc  
# rpm --import oracle_vbox.asc

Ahora habilitamos el repositorio de VirtualBox OpenSUSE en nuestro sistema (no hay archivo de repositorio para OpenSUSE 12.2 porque el archivo de repositorio para 11.4 funciona en 12.2 también):

# cd /etc/zypp/repos.d/  
# wget http://download.virtualbox.org/virtualbox/rpm/opensuse/11.4/virtualbox.repo

Ahora podemos simplemente instalar VirtualBox 4.1 de la siguiente manera:

# zypper install VirtualBox-4.2

Después, asegúrate de que el módulo del kernel vboxdrv esté cargado:

# modprobe vboxdrv

El siguiente comando asegura que el módulo del kernel vboxdrv se cargue automáticamente cada vez que inicies el sistema:

# insserv vboxdrv

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.2 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:

# cd /tmp  
# wget http://download.virtualbox.org/virtualbox/4.2.0/Oracle_VM_VirtualBox_Extension_Pack-4.2.0-80737.vbox-extpack  
# sudo VBoxManage extpack install Oracle_VM_VirtualBox_Extension_Pack-4.2.0-80737.vbox-extpack

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

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

# /usr/sbin/usermod -G vboxusers admin

(Puede que tengas que cerrar sesión y volver a iniciar sesión para que este cambio tenga efecto.)

VirtualBox ahora está instalado y listo para ser utilizado.

Escribe

# exit

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

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 512MB 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 512 --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 (incluido 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 a 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.