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

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

VBoxHeadless - Ejecutando Máquinas Virtuales Con VirtualBox 4.2 En Un Servidor Fedora 18 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 Fedora 18 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 Fedora 18 (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.2 en nuestro servidor Fedora 18, necesitamos privilegios de root, por lo tanto, ejecutamos

$ su

Asegúrate de que tu kernel esté actualizado:

yum install kernel

Si el kernel se actualiza, debes reiniciar…

reboot

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

su 

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

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

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

Ahora habilitamos el repositorio de VirtualBox Fedora en nuestro sistema:

Ahora podemos simplemente instalar VirtualBox 4.2 de la siguiente manera:

# yum install VirtualBox-4.2

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:

Paquete de Extensión Oracle VM VirtualBox 4.2.6
Soporte para dispositivos USB 2.0, RDP de VirtualBox 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.)

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.

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.

Antes de crear una máquina virtual, necesitamos averiguar cómo se llama el dispositivo de red principal en Fedora:

$ ifconfig

[admin@server1 ~]$ ifconfig
lo: flags=73 mtu 16436
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10
loop txqueuelen 0 (Local Loopback)
RX packets 6 bytes 624 (624.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 6 bytes 624 (624.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

p2p1: flags=4163 mtu 1500
inet 192.168.0.100 netmask 255.255.255.0 broadcast 192.168.0.255
inet6 fe80::a00:27ff:fe08:1269 prefixlen 64 scopeid 0x20
ether 08:00:27:08:12:69 txqueuelen 1000 (Ethernet)
RX packets 78911 bytes 113684403 (108.4 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 42260 bytes 3541430 (3.3 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

[admin@server1 ~]$

Como ves, se llama p2p1 en este caso - ten esto en cuenta.

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

$ VBoxManage createvm --name "Ubuntu 12.10 Server" --register

En el siguiente comando debemos especificar la interfaz de red correcta (p2p1 en mi caso):

$ VBoxManage modifyvm "Ubuntu 12.10 Server" --memory 1024 --acpi on --boot1 dvd --nic1 bridged --bridgeadapter1 p2p1

$ VBoxManage createhd –filename Ubuntu_12_10_Server.vdi –size 10000
$ VBoxManage storagectl “Ubuntu 12.10 Server” –name “IDE Controller” –add ide
$ VBoxManage storageattach “Ubuntu 12.10 Server” –storagectl “IDE Controller” –port 0 –device 0 –type hdd –medium Ubuntu_12_10_Server.vdi
$ VBoxManage storageattach “Ubuntu 12.10 Server” –storagectl “IDE Controller” –port 1 –device 0 –type dvddrive –medium /home/ubuntu-12.10-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.10 Server"

(Reemplaza Ubuntu 12.10 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.10 Server" poweroff

Para pausar una VM, ejecuta

$ VBoxManage controlvm "Ubuntu 12.10 Server" pause

Para reiniciar una VM, ejecuta

$ VBoxManage controlvm "Ubuntu 12.10 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.