VirtualBox: amministrazione da terminale: differenze tra le versioni

Da Guide@Debianizzati.Org.
Vai alla navigazione Vai alla ricerca
Nessun oggetto della modifica
Nessun oggetto della modifica
Riga 2: Riga 2:
=Introduzione=
=Introduzione=
Virtualbox è un software di virtualizzazione sviluppato da Sun; normalmente viene utilizzato come un normale programma dotato di interfaccia grafica, ma con qualche accorgimento è possibile installarlo e utilizzarlo anche su una macchina server dove non sia stato installato il server grafico X.org.<br>
Virtualbox è un software di virtualizzazione sviluppato da Sun; normalmente viene utilizzato come un normale programma dotato di interfaccia grafica, ma con qualche accorgimento è possibile installarlo e utilizzarlo anche su una macchina server dove non sia stato installato il server grafico X.org.<br>
La configurazione della macchina host presa in esame per la guida prevede come indirizzo IP di <tt>eth0</tt> il seguente: <tt>'''192.168.0.100'''</tt>.
La configurazione della macchina host presa in esame per la guida prevede come indirizzo IP di <code>eth0</code> il seguente: <code>'''192.168.0.100'''</code>.
=Installazione=
=Installazione=
VirtualBox è rilasciato in due versioni e con due licenze diverse: la versione opensource ha alcune limitazioni (non gestisce l'USB, ad esempio); la versione completa non è opensource, ma è liberamente scaricabile per utilizzi non commerciali.<br>
VirtualBox è rilasciato in due versioni e con due licenze diverse: la versione opensource ha alcune limitazioni (non gestisce l'USB, ad esempio); la versione completa non è opensource, ma è liberamente scaricabile per utilizzi non commerciali.<br>
Per installare VirtualBox nella sua versione completa (quella opensource, chiamata <tt>virtualbox-ose</tt> è già presente nei repository di Debian) occorre aggiungere il repository di VirtualBox. Aprite il vostro sources.list:
Per installare VirtualBox nella sua versione completa (quella opensource, chiamata <code>virtualbox-ose</code> è già presente nei repository di Debian) occorre aggiungere il repository di VirtualBox. Aprite il vostro <code>sources.list</code>:
<pre>
<pre>
# nano /etc/apt/sources.list
# nano /etc/apt/sources.list
Riga 31: Riga 31:
# apt-get install linux-headers-$(uname -r) build-essential virtualbox-3.1
# apt-get install linux-headers-$(uname -r) build-essential virtualbox-3.1
</pre>
</pre>
Sostituite <tt>virtualbox-3.1</tt>
Sostituite <code>virtualbox-3.1</code>
* con <tt>virtualbox</tt> per installare VirtualBox 1.6.6
* con <code>virtualbox</code> per installare VirtualBox 1.6.6
* con <tt>virtualbox-2.0</tt> per installare VirtualBox 2.0.12
* con <code>virtualbox-2.0</code> per installare VirtualBox 2.0.12
* con <tt>virtualbox-2.1</tt> per installare VirtualBox 2.1.4
* con <code>virtualbox-2.1</code> per installare VirtualBox 2.1.4
* con <tt>virtualbox-2.2</tt> per installare VirtualBox 2.2.4
* con <code>virtualbox-2.2</code> per installare VirtualBox 2.2.4
* con <tt>virtualbox-3.0</tt> per installare VirtualBox 3.0.12
* con <code>virtualbox-3.0</code> per installare VirtualBox 3.0.12
Prima di effettuare l'installazione, controllate alla pagina http://www.virtualbox.org/wiki/Linux_Downloads che non esistano versioni più nuove di quelle elencate in questa guida; in caso ci fossero, sostituite il comando precedente con quello che si adatta alla versione che desiderate installate.<br>
Prima di effettuare l'installazione, controllate alla pagina http://www.virtualbox.org/wiki/Linux_Downloads che non esistano versioni più nuove di quelle elencate in questa guida; in caso ci fossero, sostituite il comando precedente con quello che si adatta alla versione che desiderate installate.<br>
Durante l'installazione, che purtroppo comprende come dipendenze circa 160 MB di librerie di KDE, di Gnome e di varia natura, vi verranno poste alcune domande:
Durante l'installazione, che purtroppo comprende come dipendenze circa 160 MB di librerie di KDE, di Gnome e di varia natura, vi verranno poste alcune domande:
Riga 53: Riga 53:
W: Possible missing firmware /lib/firmware/tigon/tg3.bin for module tg3
W: Possible missing firmware /lib/firmware/tigon/tg3.bin for module tg3
</pre>
</pre>
Se, come me, siete persone che non dormono all'idea di avere un sistema con un'incompletezza, aprite di nuovo il vostro <tt>sources.list</tt> e, poichè il firmware in oggetto si trova in un pacchetto disponibile solo per Sid, modificatelo aggiungendo questa riga:
Se, come me, siete persone che non dormono all'idea di avere un sistema con un'incompletezza, aprite di nuovo il vostro <code>sources.list</code> e, poiché il firmware in oggetto si trova in un pacchetto disponibile solo per Sid, modificatelo aggiungendo questa riga:
<pre>
<pre>
deb http://ftp.de.debian.org/debian sid main non-free
deb http://ftp.de.debian.org/debian sid main non-free
Riga 62: Riga 62:
# apt-get install firmware-linux-nonfree
# apt-get install firmware-linux-nonfree
</pre>
</pre>
che non porta con alcuna dipendenza.<br>
che non porta con alcuna dipendenza.<br>
Come è intuibile dal nome, siate consapevoli che state installando un pacchetto contenente firmware '''non liberi'''.<br>
Come è intuibile dal nome, siate consapevoli che state installando un pacchetto contenente firmware '''non liberi'''.<br>
Una volta completata l'operazione, modificate nuovamente il vostro <tt>sources.list</tt> ed '''eliminate ogni traccia di Sid'''!! (Siamo pur sempre su un server e vogliamo stabilità innanzitutto...).<br>
Una volta completata l'operazione, modificate nuovamente il vostro <code>sources.list</code> ed '''eliminate ogni traccia di Sid'''!! (Siamo pur sempre su un server e vogliamo stabilità innanzitutto...).<br>
Verificate infine che siano presenti i seguenti files:
Verificate infine che siano presenti i seguenti file:
<pre>
<pre>
/lib/firmware/tigon/tg3_tso5.bin  
/lib/firmware/tigon/tg3_tso5.bin  
Riga 71: Riga 71:
/lib/firmware/tigon/tg3.bin
/lib/firmware/tigon/tg3.bin
</pre>
</pre>
Per poter utilizzare VirtualBox come normale utente, occorre infine aggiungere quest'ultimo al gruppo <tt>vboxusers</tt>:
Per poter utilizzare VirtualBox come normale utente, occorre infine aggiungere quest'ultimo al gruppo <code>vboxusers</code>:
<pre>
<pre>
# adduser nome_utente vboxusers
# adduser nome_utente vboxusers
Riga 77: Riga 77:


=Utilizzare VirtualBox da linea di comando=
=Utilizzare VirtualBox da linea di comando=
VirtualBox mette a disposizione lo strumento <tt>VBoxManage</tt> per creare e amministrare le macchine virtuali da terminale. E' uno strumento molto potente e complesso e permette di gestire le proprie macchine virtuali in maniera molto dettagliata; ciononostante in questa guida vedremo solo i comandi e le opzioni principali.<br>
VirtualBox mette a disposizione lo strumento <code>VBoxManage</code> per creare e amministrare le macchine virtuali da terminale. È uno strumento molto potente e complesso e permette di gestire le proprie macchine virtuali in maniera molto dettagliata; ciononostante in questa guida vedremo solo i comandi e le opzioni principali.<br>
Per una spiegazione dettagliata del tool consiglio di far riferimento alla User Guide di VirtualBox: http://www.virtualbox.org/manual/UserManual.html#vboxmanage
Per una spiegazione dettagliata del tool consiglio di far riferimento alla User Guide di VirtualBox: http://www.virtualbox.org/manual/UserManual.html#vboxmanage
==Creazione di una Virtual Machine==
==Creazione di una Virtual Machine==
Creiamo innanzitutto una directory dove conservare tutte le nostre macchine virtuali. Io la creerò sotto <tt>/opt</tt>, ma siete liberi di metterla dove meglio credete (ricordatevi di modificare il percorso nei comandi seguenti!):
Creiamo innanzitutto una directory dove conservare tutte le nostre macchine virtuali. Io la creerò sotto <code>/opt</code>, ma siete liberi di metterla dove meglio credete (ricordatevi di modificare il percorso nei comandi seguenti!):
<pre>
<pre>
# mkdir /opt/vm
# mkdir /opt/vm
Riga 89: Riga 89:
</pre>
</pre>
Analizziamo il comando seguente:
Analizziamo il comando seguente:
* <tt>createvm</tt> indica a VBoxManage di creare una nuova virtual machine
* <code>createvm</code> indica a VBoxManage di creare una nuova virtual machine
* <tt>--name</tt> consente di specificare il nome della nuova virtual machine. Consiglio di usare nomi senza spazi o caratteri strani
* <code>--name</code> consente di specificare il nome della nuova virtual machine. Consiglio di usare nomi senza spazi o caratteri strani
* <tt>--basefolder</tt> permette di specificare la directory dove sarà creata la virtual machine. All'interno di questa directory sarà automaticamente creata una directory avente il nome che abbiamo assegnato alla virtual machine
* <code>--basefolder</code> permette di specificare la directory dove sarà creata la virtual machine. All'interno di questa directory sarà automaticamente creata una directory avente il nome che abbiamo assegnato alla virtual machine
* <tt>--register</tt> permette di importare in VirtualBox il file XML contenente le specifiche della virtual machine
* <code>--register</code> permette di importare in VirtualBox il file XML contenente le specifiche della virtual machine
<br>
<br>
Ora modifichiamo la configurazione della nostra nuova virtual machine:
Ora modifichiamo la configurazione della nostra nuova virtual machine:
Riga 99: Riga 99:
</pre>
</pre>
Le modifiche che abbiamo introdotto nella nostra virtual machine sono le seguenti:
Le modifiche che abbiamo introdotto nella nostra virtual machine sono le seguenti:
* <tt>--memory</tt> specifica in MB la dimensione della RAM da assegnare
* <code>--memory</code> specifica in MB la dimensione della RAM da assegnare
* <tt>--acpi</tt> abilita o disabilita la modalità ACPI
* <code>--acpi</code> abilita o disabilita la modalità ACPI
* <tt>--boot1</tt> specifica che il primo dispositivo di boot è nel nostro caso un DVD
* <code>--boot1</code> specifica che il primo dispositivo di boot è nel nostro caso un DVD
* <tt>--boot2</tt> specifica che il secondo dispositivo di boot è nel nostro caso l'hard disk virtuale
* <code>--boot2</code> specifica che il secondo dispositivo di boot è nel nostro caso l'hard disk virtuale
* <tt>--nic1</tt> indica che la prima interfaccia di rete virtuale utilizzerà la modalità bridge
* <code>--nic1</code> indica che la prima interfaccia di rete virtuale utilizzerà la modalità bridge
* <tt>--bridgeadapter1</tt> indica l'interfaccia di rete del nostro server Debian che verrà usata dalla virtual machine
* <code>--bridgeadapter1</code> indica l'interfaccia di rete del nostro server Debian che verrà usata dalla virtual machine
* <tt>--ostype</tt> permette di specificare il tipo di sistema virtuale che installeremo. Per un elenco si dia il comando <tt>VBoxManage list ostypes</tt>
* <code>--ostype</code> permette di specificare il tipo di sistema virtuale che installeremo. Per un elenco si dia il comando <code>VBoxManage list ostypes</code>
* <tt>--usb</tt> abilita o disabilita le porte USB
* <code>--usb</code> abilita o disabilita le porte USB
Ogni volta che, attraverso il parametro <tt>modifyvm</tt> apportate delle modifiche alla configurazione della vostra virtual machine, queste vengono registrate nel file XML creato in precedenza.
Ogni volta che, attraverso il parametro <code>modifyvm</code> apportate delle modifiche alla configurazione della vostra virtual machine, queste vengono registrate nel file XML creato in precedenza.
<br>
<br>
Ora preoccupiamoci di creare un hard disk virtuale per la nostra virtual machine:
Ora preoccupiamoci di creare un hard disk virtuale per la nostra virtual machine:
Riga 114: Riga 114:
</pre>
</pre>
Piccola spiegazione:
Piccola spiegazione:
* <tt>--filename</tt> specifica la directory dove creare il disco virtuale
* <code>--filename</code> specifica la directory dove creare il disco virtuale
* <tt>--size</tt> indica la dimensione del disco in MB
* <code>--size</code> indica la dimensione del disco in MB
<br>
<br>
Ora modifichiamo la virtual machine collegandole il disco virtuale che abbiamo appena creato:
Ora modifichiamo la virtual machine collegandole il disco virtuale che abbiamo appena creato:
Riga 121: Riga 121:
# VBoxManage modifyvm prova -hda /opt/vm/prova/prova.vdi
# VBoxManage modifyvm prova -hda /opt/vm/prova/prova.vdi
</pre>
</pre>
Possiamo collegare alla nostra macchina un massimo di 3 hard disk virtuali (<tt>hda</tt>, <tt>hdb</tt>, <tt>hdd</tt>). <tt>hdc</tt> è riservato per il CD/DVD.
Possiamo collegare alla nostra macchina un massimo di 3 hard disk virtuali (<code>hda</code>, <code>hdb</code>, <code>hdd</code>). <code>hdc</code> è riservato per il CD/DVD.
<br><br>
<br><br>
Arrivati a questo punto dobbiamo montare un'immagine ISO o un CD/DVD nel nostro lettore CD/DVD virtuale, in modo di poter installare il nostro sistema operativo virtuale. In questo esempio monterò un'immagine ISO:
Arrivati a questo punto dobbiamo montare un'immagine ISO o un CD/DVD nel nostro lettore CD/DVD virtuale, in modo di poter installare il nostro sistema operativo virtuale. In questo esempio monterò un'immagine ISO:
Riga 139: Riga 139:
# VBoxHeadless --startvm prova
# VBoxHeadless --startvm prova
</pre>
</pre>
Il comando <tt>VBoxHeadless</tt> avvia la virtual machine indicata e nel contempo inizializza una sessione VRDP Server (Virtual Remote Desktop Protocol). Purtroppo però, pur essendo il comando suggerito dalla User Guide di VirtualBox, ha il difetto di bloccare la sessione di terminale fino allo spegnimento della macchina virtuale. Per questo motivo consiglio di avviare una virtual machine con il comando alternativo:
Il comando <code>VBoxHeadless</code> avvia la virtual machine indicata e nel contempo inizializza una sessione VRDP Server (Virtual Remote Desktop Protocol). Purtroppo però, pur essendo il comando suggerito dalla User Guide di VirtualBox, ha il difetto di bloccare la sessione di terminale fino allo spegnimento della macchina virtuale. Per questo motivo consiglio di avviare una virtual machine con il comando alternativo:
<pre>
<pre>
# VBoxManage startvm prova --type vrdp
# VBoxManage startvm prova --type vrdp
Riga 147: Riga 147:
Aprite "Connessione Desktop Remoto" e digitate l'indirizzo IP del vostro server Debian: si aprirà la console della macchina virtuale che avete avviato.
Aprite "Connessione Desktop Remoto" e digitate l'indirizzo IP del vostro server Debian: si aprirà la console della macchina virtuale che avete avviato.
==Comandi utili di "Connessione Desktop Remoto"==
==Comandi utili di "Connessione Desktop Remoto"==
* <tt>ALT+PGSU</tt>: Passa da un programma all'altro da sinistra verso destra.
* <code>ALT+PGSU</code>: Passa da un programma all'altro da sinistra verso destra.
* <tt>ALT+PGGIÙ</tt>: Passa da un programma all'altro da destra verso sinistra.
* <code>ALT+PGGIU</code>: Passa da un programma all'altro da destra verso sinistra.
* <tt>ALT+INS</tt>: Passa da un programma all'altro nell'ordine in cui sono stati aperti.
* <code>ALT+INS</code>: Passa da un programma all'altro nell'ordine in cui sono stati aperti.
* <tt>ALT+HOME</tt>: Visualizza il menu Start.
* <code>ALT+HOME</code>: Visualizza il menu Start.
* <tt>CTRL+ALT+INTERR</tt>: Passa da una finestra alla modalità schermo intero e viceversa.
* <code>CTRL+ALT+INTERR</code>: Passa da una finestra alla modalità schermo intero e viceversa.
* <tt>CTRL+ALT+FINE</tt>: Visualizza la finestra di dialogo Protezione di Windows.
* <code>CTRL+ALT+FINE</code>: Visualizza la finestra di dialogo Protezione di Windows.
* <tt>ALT+CANC</tt>: Visualizza il menu Windows.
* <code>ALT+CANC</code>: Visualizza il menu Windows.
* <tt>CTRL+ALT+SEGNO MENO (-) del tastierino numerico</tt>: Copia negli Appunti del computer remoto la finestra attiva del computer client (esegue la stessa funzione della combinazione di tasti ALT+STAMP in un computer locale).
* <code>CTRL+ALT+SEGNO MENO (-) del tastierino numerico</code>: Copia negli Appunti del computer remoto la finestra attiva del computer client (esegue la stessa funzione della combinazione di tasti ALT+STAMP in un computer locale).
* <tt>CTRL+ALT+SEGNO PIÙ (+) del tastierino numerico</tt>: Copia negli Appunti del computer remoto l'intera schermata del computer client (esegue la stessa funzione del tasto STAMP in un computer locale).
* <code>CTRL+ALT+SEGNO PIÙ (+) del tastierino numerico</code>: Copia negli Appunti del computer remoto l'intera schermata del computer client (esegue la stessa funzione del tasto STAMP in un computer locale).
* <tt>CTRL+ALT+freccia DESTRA</tt>: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
* <code>CTRL+ALT+freccia DESTRA</code>: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
* <tt>CTRL+ALT+freccia SINISTRA</tt>: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
* <code>CTRL+ALT+freccia SINISTRA</code>: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
* La combinazione <tt>CTRL+ALT+CANC</tt> ha sempre effetto sul desktop del computer locale. Per inviare la combinazione <tt>CTRL+ALT+CANC</tt> al computer remoto, è necessario premere <tt>'''CTRL+ALT+FINE'''</tt>.
* La combinazione <code>CTRL+ALT+CANC</code> ha sempre effetto sul desktop del computer locale. Per inviare la combinazione <code>CTRL+ALT+CANC</code> al computer remoto, è necessario premere <code>'''CTRL+ALT+FINE'''</code>.


=Collegamento alla VM da Linux=
=Collegamento alla VM da Linux=
Riga 175: Riga 175:
=Avvio automatico di una Virtual Machine=
=Avvio automatico di una Virtual Machine=
Per avviare una virtual machine come demone al boot di Debian sono sufficienti pochi passi.<br>
Per avviare una virtual machine come demone al boot di Debian sono sufficienti pochi passi.<br>
Inannzitutto creiamo un file per il nostro script di boot:
Innanzitutto creiamo un file per il nostro script di boot:
<pre>
<pre>
# nano /etc/init.d/provavm
# nano /etc/init.d/provavm
Riga 333: Riga 333:
# chmod 755 /etc/init.d/provavm
# chmod 755 /etc/init.d/provavm
</pre>
</pre>
e creiamo i link alle directory <tt>rcX.d</tt>:
e creiamo i link alle directory <code>rcX.d</code>:
<pre>
<pre>
# update-rc.d provavm defaults
# update-rc.d provavm defaults
Riga 343: Riga 343:


=Installazione delle Guest Addictions=
=Installazione delle Guest Addictions=
Il pacchetto Guest Addictions contiene i drivers per l'hardware virtuale emulato da VirtualBox e, se installato, permette di migliorare stabilità e prestazioni della nostra virtual machine.<br>
Il pacchetto Guest Addictions contiene i driver per l'hardware virtuale emulato da VirtualBox e, se installato, permette di migliorare stabilità e prestazioni della nostra virtual machine.<br>
In maniera molto semplice, io ho scaricato l'immagine ISO delle Guest Addictions da qui: http://download.virtualbox.org/virtualbox/ , stando bene attento a scegliere la versione di VirtualBox che ho installato sul server. Poi ho montato l'immagine ISO all'interno del sistema operativo virtuale e ho installato i drivers.
In maniera molto semplice, io ho scaricato l'immagine ISO delle Guest Addictions da qui: http://download.virtualbox.org/virtualbox/ , stando bene attento a scegliere la versione di VirtualBox che ho installato sul server. Poi ho montato l'immagine ISO all'interno del sistema operativo virtuale e ho installato i driver.


=Salvare uno snapshot di una Virtual Machine=
=Salvare uno snapshot di una Virtual Machine=

Versione delle 18:14, 31 gen 2010

Debian-swirl.png Versioni Compatibili

ERRORE: valore non valido ( Debian Sarge 3.1
Debian Etch 4.0
Debian Lenny 5.0
Debian Squeeze
Debian Sid )! Vedi qui.

Introduzione

Virtualbox è un software di virtualizzazione sviluppato da Sun; normalmente viene utilizzato come un normale programma dotato di interfaccia grafica, ma con qualche accorgimento è possibile installarlo e utilizzarlo anche su una macchina server dove non sia stato installato il server grafico X.org.
La configurazione della macchina host presa in esame per la guida prevede come indirizzo IP di eth0 il seguente: 192.168.0.100.

Installazione

VirtualBox è rilasciato in due versioni e con due licenze diverse: la versione opensource ha alcune limitazioni (non gestisce l'USB, ad esempio); la versione completa non è opensource, ma è liberamente scaricabile per utilizzi non commerciali.
Per installare VirtualBox nella sua versione completa (quella opensource, chiamata virtualbox-ose è già presente nei repository di Debian) occorre aggiungere il repository di VirtualBox. Aprite il vostro sources.list:

# nano /etc/apt/sources.list

e aggiungete una di queste righe:

  • Lenny
deb http://download.virtualbox.org/virtualbox/debian lenny non-free
  • Etch
deb http://download.virtualbox.org/virtualbox/debian etch non-free
  • Sarge
deb http://download.virtualbox.org/virtualbox/debian sarge non-free

Quindi importate la chiave del repository:

# wget -q http://download.virtualbox.org/virtualbox/debian/sun_vbox.asc -O- | apt-key add -

aggiornate la lista dei pacchetti e infine installate VirtualBox:

# apt-get update
# apt-get install linux-headers-$(uname -r) build-essential virtualbox-3.1

Sostituite virtualbox-3.1

  • con virtualbox per installare VirtualBox 1.6.6
  • con virtualbox-2.0 per installare VirtualBox 2.0.12
  • con virtualbox-2.1 per installare VirtualBox 2.1.4
  • con virtualbox-2.2 per installare VirtualBox 2.2.4
  • con virtualbox-3.0 per installare VirtualBox 3.0.12

Prima di effettuare l'installazione, controllate alla pagina http://www.virtualbox.org/wiki/Linux_Downloads che non esistano versioni più nuove di quelle elencate in questa guida; in caso ci fossero, sostituite il comando precedente con quello che si adatta alla versione che desiderate installate.
Durante l'installazione, che purtroppo comprende come dipendenze circa 160 MB di librerie di KDE, di Gnome e di varia natura, vi verranno poste alcune domande:

Creating group 'vboxusers'
Users of VirtualBox must be member of that group in order to have
write permissions to /dev/vboxdrv. Otherwise starting of VMs will not be possible. <---- Ok

Unable to find a precompiled module for the current kernel! [...]
Should the vboxdrv kernel module be compiled now? <---- Yes

Probabilmente alla fine della compilazione vi sarete trovati questo messaggio d'avvertimento:

W: Possible missing firmware /lib/firmware/tigon/tg3_tso5.bin for module tg3
W: Possible missing firmware /lib/firmware/tigon/tg3_tso.bin for module tg3
W: Possible missing firmware /lib/firmware/tigon/tg3.bin for module tg3

Se, come me, siete persone che non dormono all'idea di avere un sistema con un'incompletezza, aprite di nuovo il vostro sources.list e, poiché il firmware in oggetto si trova in un pacchetto disponibile solo per Sid, modificatelo aggiungendo questa riga:

deb http://ftp.de.debian.org/debian sid main non-free

Quindi installate il pacchetto:

# apt-get update
# apt-get install firmware-linux-nonfree

che non porta con sé alcuna dipendenza.
Come è intuibile dal nome, siate consapevoli che state installando un pacchetto contenente firmware non liberi.
Una volta completata l'operazione, modificate nuovamente il vostro sources.list ed eliminate ogni traccia di Sid!! (Siamo pur sempre su un server e vogliamo stabilità innanzitutto...).
Verificate infine che siano presenti i seguenti file:

/lib/firmware/tigon/tg3_tso5.bin 
/lib/firmware/tigon/tg3_tso.bin 
/lib/firmware/tigon/tg3.bin

Per poter utilizzare VirtualBox come normale utente, occorre infine aggiungere quest'ultimo al gruppo vboxusers:

# adduser nome_utente vboxusers

Utilizzare VirtualBox da linea di comando

VirtualBox mette a disposizione lo strumento VBoxManage per creare e amministrare le macchine virtuali da terminale. È uno strumento molto potente e complesso e permette di gestire le proprie macchine virtuali in maniera molto dettagliata; ciononostante in questa guida vedremo solo i comandi e le opzioni principali.
Per una spiegazione dettagliata del tool consiglio di far riferimento alla User Guide di VirtualBox: http://www.virtualbox.org/manual/UserManual.html#vboxmanage

Creazione di una Virtual Machine

Creiamo innanzitutto una directory dove conservare tutte le nostre macchine virtuali. Io la creerò sotto /opt, ma siete liberi di metterla dove meglio credete (ricordatevi di modificare il percorso nei comandi seguenti!):

# mkdir /opt/vm

Procediamo quindi a creare la nostra virtual machine di prova:

# VBoxManage createvm --name prova --basefolder /opt/vm/ --register

Analizziamo il comando seguente:

  • createvm indica a VBoxManage di creare una nuova virtual machine
  • --name consente di specificare il nome della nuova virtual machine. Consiglio di usare nomi senza spazi o caratteri strani
  • --basefolder permette di specificare la directory dove sarà creata la virtual machine. All'interno di questa directory sarà automaticamente creata una directory avente il nome che abbiamo assegnato alla virtual machine
  • --register permette di importare in VirtualBox il file XML contenente le specifiche della virtual machine


Ora modifichiamo la configurazione della nostra nuova virtual machine:

# VBoxManage modifyvm prova --memory 1024MB --acpi on --boot1 dvd --boot2 disk --nic1 bridged --bridgeadapter1 eth0 --ostype Windows2003 --usb on

Le modifiche che abbiamo introdotto nella nostra virtual machine sono le seguenti:

  • --memory specifica in MB la dimensione della RAM da assegnare
  • --acpi abilita o disabilita la modalità ACPI
  • --boot1 specifica che il primo dispositivo di boot è nel nostro caso un DVD
  • --boot2 specifica che il secondo dispositivo di boot è nel nostro caso l'hard disk virtuale
  • --nic1 indica che la prima interfaccia di rete virtuale utilizzerà la modalità bridge
  • --bridgeadapter1 indica l'interfaccia di rete del nostro server Debian che verrà usata dalla virtual machine
  • --ostype permette di specificare il tipo di sistema virtuale che installeremo. Per un elenco si dia il comando VBoxManage list ostypes
  • --usb abilita o disabilita le porte USB

Ogni volta che, attraverso il parametro modifyvm apportate delle modifiche alla configurazione della vostra virtual machine, queste vengono registrate nel file XML creato in precedenza.
Ora preoccupiamoci di creare un hard disk virtuale per la nostra virtual machine:

# VBoxManage createhd --filename /opt/vm/prova/prova.vdi --size 10000 --register

Piccola spiegazione:

  • --filename specifica la directory dove creare il disco virtuale
  • --size indica la dimensione del disco in MB


Ora modifichiamo la virtual machine collegandole il disco virtuale che abbiamo appena creato:

# VBoxManage modifyvm prova -hda /opt/vm/prova/prova.vdi

Possiamo collegare alla nostra macchina un massimo di 3 hard disk virtuali (hda, hdb, hdd). hdc è riservato per il CD/DVD.

Arrivati a questo punto dobbiamo montare un'immagine ISO o un CD/DVD nel nostro lettore CD/DVD virtuale, in modo di poter installare il nostro sistema operativo virtuale. In questo esempio monterò un'immagine ISO:

# VBoxManage openmedium dvd /home/ferdy/w2003.iso
# VBoxManage modifyvm "prova" -dvd /home/ferdy/w2003.iso

Importazione di una Virtual Machine

Se abbiamo già una virtual machine creata in precedenza, possiamo importarla all'interno della nostra installazione di VirtualBox per poi avviarla. Per importare una virtual machine esistente si utilizzi il comando:

# VBoxManage registervm /opt/vm/prova2/prova2.xml

Avvio e gestione di una Virtual Machine

Arrivati a questo punto possiamo avviare la nostra virtual machine con il comando:

# VBoxHeadless --startvm prova

Il comando VBoxHeadless avvia la virtual machine indicata e nel contempo inizializza una sessione VRDP Server (Virtual Remote Desktop Protocol). Purtroppo però, pur essendo il comando suggerito dalla User Guide di VirtualBox, ha il difetto di bloccare la sessione di terminale fino allo spegnimento della macchina virtuale. Per questo motivo consiglio di avviare una virtual machine con il comando alternativo:

# VBoxManage startvm prova --type vrdp

dagli effetti identici al precedente, ma senza che la nostra shell sia resa inutilizzabile.

Collegamento alla VM da Windows XP

Aprite "Connessione Desktop Remoto" e digitate l'indirizzo IP del vostro server Debian: si aprirà la console della macchina virtuale che avete avviato.

Comandi utili di "Connessione Desktop Remoto"

  • ALT+PGSU: Passa da un programma all'altro da sinistra verso destra.
  • ALT+PGGIU: Passa da un programma all'altro da destra verso sinistra.
  • ALT+INS: Passa da un programma all'altro nell'ordine in cui sono stati aperti.
  • ALT+HOME: Visualizza il menu Start.
  • CTRL+ALT+INTERR: Passa da una finestra alla modalità schermo intero e viceversa.
  • CTRL+ALT+FINE: Visualizza la finestra di dialogo Protezione di Windows.
  • ALT+CANC: Visualizza il menu Windows.
  • CTRL+ALT+SEGNO MENO (-) del tastierino numerico: Copia negli Appunti del computer remoto la finestra attiva del computer client (esegue la stessa funzione della combinazione di tasti ALT+STAMP in un computer locale).
  • CTRL+ALT+SEGNO PIÙ (+) del tastierino numerico: Copia negli Appunti del computer remoto l'intera schermata del computer client (esegue la stessa funzione del tasto STAMP in un computer locale).
  • CTRL+ALT+freccia DESTRA: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
  • CTRL+ALT+freccia SINISTRA: Consente di spostarsi al di fuori dei controlli di Desktop remoto su un controllo nel programma host, ad esempio un pulsante o una casella di testo. Utile quando i controlli di Desktop remoto sono incorporati in un altro programma (host).
  • La combinazione CTRL+ALT+CANC ha sempre effetto sul desktop del computer locale. Per inviare la combinazione CTRL+ALT+CANC al computer remoto, è necessario premere CTRL+ALT+FINE.

Collegamento alla VM da Linux

Aprite un terminale e digitate:

$ rdesktop -a 16 192.168.0.100

Si aprirà la console della macchina virtuale che avete avviato.

Arresto della VM

Per arrestare la virtual machine si usi il comando:

# VBoxManage controlvm prova savestate

Avvio automatico di una Virtual Machine

Per avviare una virtual machine come demone al boot di Debian sono sufficienti pochi passi.
Innanzitutto creiamo un file per il nostro script di boot:

# nano /etc/init.d/provavm

e inseriamoci questo codice:

#! /bin/sh
### BEGIN INIT INFO
# Provides: VirtualBox - VM di Prova
# Default-Start: 2 3 4 5
# Default-Stop: S 0 1 6
### END INIT INFO

# Author: Ferdinando Bassi per Debianizzati.org

# Do NOT "set -e"

# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/usr/sbin:/usr/bin:/sbin:/bin

#
# DA CAMBIARE E DA ADATTARE
#
# Name given to the virtual machine
VM_NAME="prova"

# Name of this file, excluding /etc/init.d/
THIS_FILE=provavm

# Username to run as
RUNAS_USERNAME=root

#
# FINE SEZIONE DA MODIFICARE
#

DESC="VirtualBox - ${VM_NAME}"
DAEMON=/usr/bin/VBoxVRDP
DAEMON_ARGS="-startvm \"${VM_NAME}\""
PIDFILE=/var/run/$THIS_FILE.pid
SCRIPTNAME=/etc/init.d/$THIS_FILE

# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0

# Read configuration variable file if it is present
[ -r /etc/default/$THIS_FILE ] && . /etc/default/$THIS_FILE

# Load the VERBOSE setting and other rcS variables
[ -f /etc/default/rcS ] && . /etc/default/rcS

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions

#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
#start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
#|| return 1
#start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
#$DAEMON_ARGS \
#|| return 2
# Add code here, if necessary, that waits for the process to be ready
# to handle requests from services started subsequently which depend
# on this one. As a last resort, sleep for some time.

su $RUNAS_USERNAME -c "VBoxManage startvm ${VM_NAME} --type vrdp"
}

#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $THIS_FILE
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
# Wait for children to finish too if this is a daemon that forks
# and if the daemon is only ever run from this initscript.
# If the above conditions are not satisfied then add some other code
# that waits for the process to drop all resources that could be
# needed by services started subsequently. A last resort is to
# sleep for some time.

su $RUNAS_USERNAME -c "VBoxManage controlvm ${VM_NAME} savestate"

start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
[ "$?" = 2 ] && return 2
# Many daemons don't delete their pidfiles when they exit.
rm -f $PIDFILE
return "$RETVAL"
}

#
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
#
# If the daemon can reload its configuration without
# restarting (for example, when it is sent a SIGHUP),
# then implement that here.
#
# start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
echo "Reload not supported"
return 0
}

case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$THIS_FILE"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$THIS_FILE"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
#reload|force-reload)
#
# If do_reload() is not implemented then leave this commented out
# and leave 'force-reload' as an alias for 'restart'.
#
#log_daemon_msg "Reloading $DESC" "$NAME"
#do_reload
#log_end_msg $?
#;;
*)
#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
echo "Usage: $SCRIPTNAME {start|stop}" >&2
exit 3
;;
esac

:

Rendiamo eseguibile lo script appena creato:

# chmod 755 /etc/init.d/provavm

e creiamo i link alle directory rcX.d:

# update-rc.d provavm defaults

Da questo momento possiamo gestire il servizio con i soliti comandi:

# /etc/init.d/provavm start|stop

Installazione delle Guest Addictions

Il pacchetto Guest Addictions contiene i driver per l'hardware virtuale emulato da VirtualBox e, se installato, permette di migliorare stabilità e prestazioni della nostra virtual machine.
In maniera molto semplice, io ho scaricato l'immagine ISO delle Guest Addictions da qui: http://download.virtualbox.org/virtualbox/ , stando bene attento a scegliere la versione di VirtualBox che ho installato sul server. Poi ho montato l'immagine ISO all'interno del sistema operativo virtuale e ho installato i driver.

Salvare uno snapshot di una Virtual Machine

Anche da linea di comando è possibile lavorare con gli snapshot di una macchina virtuale. Vediamo come.

  • Salvare uno snapshot:
# VBoxManage snapshot prova take prova1 --description descrizione
  • Cancellare uno snapshot:
# VBoxManage snapshot prova discard prova1
  • Ripristinare lo snapshot precedente:
# VBoxManage snapshot prova discardcurrent --state
  • Saltare l'ultimo snapshot e ripristinare lo snapshot precedente:
# VBoxManage snapshot prova discardcurrent --all



Ferdybassi