Virtualização · 6 min read · Dec 26, 2025

VBoxHeadless - Executando Máquinas Virtuais Com VirtualBox 4.1 Em Um Servidor CentOS 6.2 Sem Cabeça

VBoxHeadless - Executando Máquinas Virtuais Com VirtualBox 4.1 Em Um Servidor CentOS 6.2 Sem Cabeça

Versão 1.0
Autor: Falko Timme
Siga-me no Twitter

Este guia explica como você pode executar máquinas virtuais com VirtualBox 4.1 em um servidor CentOS 6.2 sem cabeça. Normalmente, você usa a GUI do VirtualBox para gerenciar suas máquinas virtuais, mas um servidor não tem um ambiente de desktop. Felizmente, o VirtualBox vem com uma ferramenta chamada VBoxHeadless que permite que você se conecte às máquinas virtuais por meio de uma conexão de desktop remoto, então não há necessidade da GUI do VirtualBox.

Não dou nenhuma garantia de que isso funcionará para você!

1 Nota Preliminar

Eu testei isso em um servidor CentOS 6.2 (sistema host) com o endereço IP 192.168.0.100 onde estou logado como um usuário normal (nome de usuário admin neste exemplo) em vez de como root.

Se você só tem uma conta root, mas não uma conta de usuário normal, crie uma da seguinte forma (usuário admin, grupo admin)…

… crie uma senha para o novo usuário…

# passwd admin

… e faça login como esse usuário.

2 Instalando o VirtualBox

Para instalar o VirtualBox 4.1 em nosso servidor CentOS 6.2, precisamos de privilégios de root, portanto, executamos

$ su

Em seguida, instalamos as dependências para o VirtualBox 4.1 da seguinte forma:

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

Com o último comando, instalamos os cabeçalhos do kernel do nosso kernel atualmente utilizado. Os cabeçalhos estão localizados no diretório /usr/src/kernels/, mas é provável que seu diretório não tenha o nome -, mas tenha um nome diferente, de modo que o módulo do kernel do VirtualBox não possa ser construído mais tarde porque o diretório de cabeçalhos do kernel esperado não pode ser encontrado. Vamos corrigir isso agora:

Verifique sua versão do kernel…

# uname -r

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

Isso significa que deve haver um diretório chamado 2.6.32-220.el6.x86_64 no diretório /usr/src/kernels/. Podemos verificar isso agora:

[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 você vê, eu tenho o diretório 2.6.32-220.23.1.el6.x86_64, mas não 2.6.32-220.el6.x86_64. Portanto, criamos um link simbólico chamado 2.6.18-238.el5-x86_64 que aponta para 2.6.18-238.9.1.el5-x86_64:

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

Em seguida, baixe e registre a chave pública rpm do VirtualBox:

Agora habilitamos o repositório do VirtualBox CentOS em nosso sistema:

Agora podemos simplesmente instalar o VirtualBox 4.1 da seguinte forma:

# yum install VirtualBox-4.1

Se a instalação for bem-sucedida, a saída deve terminar da seguinte forma:

[…]
Executando Transação
Instalando : VirtualBox-4.1-4.1.18_78361_rhel6-1.x86_64 1/1

Criando grupo ‘vboxusers’. Usuários de VM devem ser membros desse grupo!

Nenhum módulo pré-compilado para este kernel encontrado – tentando construir um. Mensagens
emitidas durante a compilação do módulo serão registradas em /var/log/vbox-install.log.

Parando módulos do kernel do VirtualBox [ OK ]
Desinstalando módulos do kernel do VirtualBox DKMS antigos [ OK ]
Tentando registrar os módulos do kernel do VirtualBox usando DKMS [ OK ]
Iniciando módulos do kernel do VirtualBox [ OK ]

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

Completo!
[root@server1 kernels]#

(Se a instalação falhar porque o diretório correto dos cabeçalhos do kernel não pode ser encontrado, a saída terminará da seguinte forma:

[…]
Executando Transação
Instalando : VirtualBox-4.1-4.1.18_78361_rhel6-1.x86_64 1/1

Criando grupo ‘vboxusers’. Usuários de VM devem ser membros desse grupo!

Nenhum módulo pré-compilado para este kernel encontrado – tentando construir um. Mensagens
emitidas durante a compilação do módulo serão registradas em /var/log/vbox-install.log.

Parando módulos do kernel do VirtualBox [ OK ]
Desinstalando módulos do kernel do VirtualBox DKMS antigos [ OK ]
Tentando registrar os módulos do kernel do VirtualBox usando DKMS
Erro! Sua fonte do kernel para o kernel 2.6.32-220.el6.x86_64 não pode ser encontrada em
/lib/modules/2.6.32-220.el6.x86_64/build ou /lib/modules/2.6.32-220.el6.x86_64/source.
[FAILED]
(Falhou, tentando sem DKMS)
Recompilando módulos do kernel do VirtualBox [FAILED]
(Veja /var/log/vbox-install.log para descobrir o que deu errado)

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

Completo!
[root@server1 kernels]#

Neste caso, tente criar o link simbólico correto do kernel (como mostrado antes) e depois execute

# /etc/init.d/vboxdrv setup

para criar o módulo do kernel do VirtualBox.)

Agora devemos adicionar o usuário que executará o VirtualBox (admin neste exemplo) ao grupo vboxusers:

# /usr/sbin/usermod -G vboxusers admin

O VirtualBox agora está instalado e pronto para ser usado.

A partir da versão 4.0, o VirtualBox introduziu os chamados “packs de extensão” e terceirizou algumas funcionalidades, como suporte a conexão de desktop remoto (VRDP), que fazia parte dos pacotes do VirtualBox antes da versão 4.0, para esses packs de extensão. Como precisamos de conexões de desktop remoto para controlar nossas máquinas virtuais, precisamos instalar o pack de extensão apropriado agora. Vá para http://www.virtualbox.org/wiki/Downloads, e você encontrará um link para o seguinte pack de extensão:

VirtualBox 4.1.18 Oracle VM VirtualBox Extension Pack
Suporte para dispositivos USB 2.0, RDP do VirtualBox e inicialização PXE para placas Intel.

Baixe e instale o pack de extensão da seguinte forma:

(Assegure-se de pegar a versão mais recente do site do VirtualBox.)

Digite

# exit

para sair da conta root e se tornar um usuário normal (admin) novamente.

3 Usando o VirtualBox Na Linha de Comando

3.1 Criando Uma VM

Para criar uma VM na linha de comando, podemos usar o comando VBoxManage. Veja

$ VBoxManage --help

para uma lista de opções disponíveis e (altamente recomendado!) dê uma olhada em http://www.virtualbox.org/manual/ch08.html.

Agora vou criar uma VM Ubuntu 12.04 Server com 1024MB de memória e um disco rígido de 10GB a partir da imagem iso do Ubuntu 12.04 Server (que eu armazenei em /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 Uma VM Existente

Vamos supor que você tenha uma VM chamada examplevm que deseja reutilizar neste host. No host antigo, você deve ter um diretório Machines/examplevm no diretório do VirtualBox; Machines/examplevm deve conter o arquivo examplevm.xml. Copie o diretório examplevm (incluindo o arquivo examplevm.xml) para o seu novo diretório Machines (se seu nome de usuário for admin, este é /home/admin/.VirtualBox/Machines - o resultado deve ser /home/admin/.VirtualBox/Machines/examplevm/examplevm.xml).

Além disso, copie o arquivo examplevm.vdi do antigo diretório VDI para o novo (por exemplo, /home/admin/.VirtualBox/VDI/examplevm.vdi).

Depois, você deve registrar a VM importada:

$ VBoxManage registervm Machines/examplevm/examplevm.xml

3.3 Iniciando Uma VM Com VBoxHeadless

Independentemente de você criar uma nova VM ou importar uma antiga, você pode iniciá-la com o comando:

$ VBoxHeadless --startvm "Ubuntu 12.04 Server"

(Substitua Ubuntu 12.04 Server pelo nome da sua VM.)

VBoxHeadless iniciará a VM e um servidor VRDP (VirtualBox Remote Desktop Protocol) que permite que você veja a saída da VM remotamente em outra máquina.

Para parar uma VM, execute

 $ VBoxManage controlvm "Ubuntu 12.04 Server" poweroff

Para pausar uma VM, execute

$ VBoxManage controlvm "Ubuntu 12.04 Server" pause

Para reiniciar uma VM, execute

$ VBoxManage controlvm "Ubuntu 12.04 Server" reset

Para saber mais sobre o VBoxHeadless, dê uma olhada em

$ VBoxHeadless --help

e em http://www.virtualbox.org/manual/ch07.html#vboxheadless.

Share: X/Twitter LinkedIn

Receba novas postagens na sua caixa de entrada

Sem spam. Cancele a assinatura a qualquer momento.