Document-page-setup.png Attenzione: questo articolo è ancora incompleto e in fase di scrittura da parte del suo autore.

Sentitevi liberi di contribuire, proponendo modifiche alla guida tramite l'apposita pagina di discussione, in modo da non interferire con il lavoro portato avanti sulla voce. Per altre informazioni si rimanda al template.


Debian-swirl.png Versioni Compatibili

ERRORE: valore non valido ( Debian Lenny 5.0 e superiore )! Vedi qui.

Introduzione

  ATTENZIONE
La presente guida è solo una bozza e deve essere ancora revisionata. Attenzione a impartire gli ordini a GRUB, un errato input potrebbe rendere il sistema non più caricabile.


Con questa guida si intende analizzare la versione di Grub 1.x nota anche come GRUB2. Per la versione precedente, rinominata ora Grub Legacy, fare riferimento all'altra guida. Per un rapido scorcio sulle differenze tra i due ed i possibili comandi utilizzabili da shell rimando qui

Il presente HOWTO nasce dalla traduzione del wiki di GRUB 2 poi successivamente rivisto ed integrato con altri spunti tratti dalla rete.

Grub è uno strumento molto potente che dovrebbe essere sempre presente nella scatola degli attrezzi di ogni amante del Free Software. Con Grub è possibile avviare qualsiasi Sistema Operativo ed anche altri bootloader.

 
Versione di riferimento al momento della stesura della presente guida: grub 1.98

Principale differenze tra GRUB Legacy e GRUB 2

  • Il file menu.lst non controlla più il menù.
  • grub.cfg gestisce il menù.
  • Il file grub.cfg è generato autonomamente dagli script di GRUB 2.
  • Il sistema di numerazione delle partizioni è leggermente diverso.
  • Cambia leggermente la sintassi del file menu.lst (GRUB 1) rispetto a grub.cfg (GRUB 2) e non è direttamente importabile in quest'ultimo.

Per saperne di più su GRUB 1, seguire il link. Per GRUB 2 continuate a leggere!

Grub 2 in Debian

Qualora sulla vostra Debian non sia presente grub 2, i pacchetti di riferimento sono i seguenti:

- grub-pc
- grub-common

Configurazione

I file principali

I file per la vostra configurazione dovrebbero trovarsi nei seguenti tre percorsi:

  • /etc/default/grub: contiene configurazioni generali, autogenerate da grub-set-default, che generalmente non richiedono cambiamenti (secondi al boot, dimensione schermata...).
  • /etc/grub.d/: è la cartella che contiene degli script di shell i quali generano il menù di grub.
  • /boot/grub/: qui il bootloader cerca i file di configurazione (grub.conf). N.B.: questi sono generati dagli script contenuti in /etc/grub, modificare quindi questi ultimi se non si vuole che le modifiche vengano sovrascritte.

Osservazioni

Pertanto si può osservare una separazione da quello che è il bootloader proprio (/boot/grub) e quelle che sono le utility necessarie alla sua configurazione (/etc/grub.d e script di configurazione). Inoltre con /etc/grub.d il menù ha assunto una forma modulare, disponendo di uno script di configurazione per ogni voce del menù.

Si sottolinea che la directory /boot/grub è modifica, o creata ex novo, tramite il comando grub-install, lo stesso comando che provvede inoltre all'installazione di GRUB sul punto di boot.

/etc/grub.d

In questa directory ci sono i file con cui viene costruita la configurazione di GRUB2. Infatti la configurazione vera e propria si trova nel file /boot/grub/grub.cfg, e viene scritta tramite un comando apposito della shell (grub-mkconfig), che prende il contenuto dei file che si trovano in /etc/grub.d e lo scrive in grub.cfg: per verificare, usare il comando $ less /boot/grub/grub.cfg. I file vengono aggiunti a grub.cfg in ordine alfabetico (ciò spiega il nome con un numero iniziale), e vengono aggiunti solo se sono eseguibili (per renderli tali, si usa il comando # chmod +x nomefile). I nomi dei file sono abbastanza esplicativi. Probabilmente i più interessanti per gli utenti sono 05_debian_theme e 40_custom, come si vede qui di seguito.

Impostare uno sfondo

Analizzando 05_debian_theme, si capisce come impostare una immagine di sfondo per grub: bisogna modificare la variabile WALLPAPER. A questo punto si può intervenire in 2 modi: o modificando direttamente il file 05_debian_theme, oppure copiando 05_debian_theme in un nuovo file, ad esempio 07_mio_debian_theme (lo scrivente preferisce il secondo metodo, allo scopo di tenere una copia intatta del file originale), ricordando di renderlo eseguibile con # chmod +x 07_mio_debian_theme e di disattivare il file originale con # chmod a-x 05_debian_theme. Dopodichè basta modificare nel nuovo file la riga n. 10 del file, impostando la variabile WALLPAPER con il percorso che porta al file che abbiamo scelto come sfondo (attualmente sono supportati file png, tga, jpg, come si può vedere nella parte # check for usable backgrounds che si trova di seguito nel file). L' output del comando grub-mkconfig ci dirà se l' immagine sarà impostata correttamente tramite il messaggio Found background image: nome_file.

Cambiare la risoluzione del terminale

La risoluzione si imposta tramite il parametro set gfxpayload (ad esempio set gfxpayload=1024x768x24). Lo scrivente ha usato il file 40_custom a tal proposito. Attenzione ad inserire dei valori compatibili con l' hardware in uso: entrando nella command-line di grub2, usare il comando vbeinfo per vedere quali risoluzioni sono supportate.

/etc/default/grub

In questo file ci sono altri parametri da configurare, ben commentati. Un parametro interessante è GRUB_GFXMODE: serve ad impostare la risoluzione di grub2 (non del terminale, che viene impostata con set gfxpayload). Attenzione ad inserire dei valori compatibili con l' hardware in uso: entrando nella command-line di grub2, usare il comando vbeinfo per vedere quali risoluzioni sono supportate.
Sono importanti anche GRUB_CMDLINE_LINUX_DEFAULT e GRUB_CMDLINE_LINUX: servono per passare parametri al kernel linux.

Rendere effettiva la configurazione

Ogni volta che si modifica un file in /etc/grub.d bisogna generare il file /boot/grub/grub.cfg tramite il comando # grub-mkconfig. Dopodichè è necessario fare leggere a grub2 questa nuova configurazione con il comando # update-grub. Questo ultimo comando è necessario anche in caso di modifica del file /etc/default/grub.

Altri file rilevanti

In questa sezione si riportano alcuni file che, seppure non essenziali alla configurazione di GRUB, possono essere d'aiuto nella sua configurazione o nella risoluzione di eventuali problematiche.

/boot/grub/device.map: qui è riportata la corrispondenza tra i nomi degli Hard Disk secondo Debian (/dev/sdX... /dev/hdX...) rispetto alla nomenclatura di GRUB.

Modificare il menù di GRUB

Comandi shell per la gestione e l'installazione di GRUB

Ora che abbiamo una idea di cosa sia e come funzioni GRUB2 passiamo all'analisi dei comandi da invocare per il settaggio. I comandi da dare culmineranno con grub-install che esegue l'effettiva modifica del punto di boot (Master Boot Record).

  • grub-probe: per indicare dove cercare i kernel, quali moduli utilizzare, cosa attualmente è presente.
  • grub-mkconfig: genera il file di configurazione grub.cfg
  • grub-mkimage: crea immagine binaria di GRUB bootabile.
  • grub-setup: scrive GRUB sull'HD specificato.
  • grub-install: esegue una serie di operazioni tale da rendere il sistema avviabile, come specificato in seguito.

Analisi di grub-install

Il programma grub-install è uno script abbastanza articolato con la funzione di rendere il nostro sistema bootabile. A grandi linee i compiti che svolge sono i seguenti:

  1. Serie di comandi di verifica quali:
    • veridica che i comandi grub-setup, grub-mkimage e grub-mkdevicemap siano stati eseguiti con successo e correttamente;
    • se non presente crea la cartella /boot/grub e la riempie;
    • crea, qualora non presente, la device.map.
  2. Lancia grub-probe (usando i moduli presenti in /boot/grub) per generare core.img (secondo la variabile --root-directory=):
    • individua il File System;
    • legge la tabella di partizioni sul supporto da scrivere;
    • individua su di esso altre possibili astrazioni (LVM, RAID...).
  3. Grub-mkimage crea core.img secondo le opzioni finora individuate.
  4. È lanciato grub-setup per la scrittura sul Master Boot Record.

Installare GRUB 2

Installare GRUB 2 su chiavetta USB

Nel seguente esempio viene installato GRUB2 su una chiavetta USB (nel specifico caso /dev/sdb) per caricare il sistema operativo installato sulla chiavetta stessa (la cui root è temporaneamente montata in ~/usbdrive)

# grub-install --root-directory=~/usbdrive/ /dev/sdb

Per maggiori informazioni, leggere qui.

Prompt di GRUB, come risolvere i problemi

Quando qualcosa va storto configurazione indicata nel menù di avvio di GRUB (ad esempio non trova il kernel), allora abbandona con il seguente prompt:

grub>

Vengono resi disponibili una serie di comandi tale da rendere possibile l'analisi dell'errore e rendere un sistema caricabile.

lista comandi

Ecco un riassunto dei principali comandi da sapere per risolvere gli eventuali problemi. Eseguendo i comandi nell'ordine riportato dovrebbe essere possibile avviare il proprio sistema operativo.

  • help: mostra tutti i comandi disponibili;
  • ls: come in bash (LiSt) mostra i file presenti. Il comando ls / mostra cosa grub utilizza quale /boot. Se correttamente indicata dovrebbe esserci almeno un kernel presente...
  • cat (/boot/)grub/grub.cfg: legge il file grub.cfg, utile per comprendere l'errore avvenuto in fase di boot;
  • set root=/dev/sda2: identifica la cartella di root, il parametro può essere dato assieme al comando linux come segue;
  • linux (hd0,2)/boot/vmlinuz-<alternate_version> root=/dev/sda2: il comando linux ha la funzione di caricare il kernel in ram. Nell'esempio riportato viene caricato il kernel presente sulla seconda partizione del primo device (hd0,2) utilizzando come cartella di root la medesima partizione (/dev/sda2);
  • linux16 /memtest86+: comando simile a linux, ma per immagini a 16 bit quale ad esempio il memtest;
  • initrd /initrd-<your_initrd>: carica in memoria l'initrd (se necessario);
  • boot: avvia il kernel caricato in memoria

Inoltre si segnala:

  • insmode <modulo>: carica il modulo indicato, utile sia per caricare i moduli del RAID o LVM, sia per passare dal prompt grub-rescue a grub normale.

Grub-rescue

Situazioni di panico!

Penso capiti a tutti almeno una volta: il sistema non parte. Innanzi tutto state tranquilli, se il problema è legato a GRUB allora il vostro sistema è ancora salvo e non aspetta altro che essere lanciato. La situazione sarà facilmente ripristinabile senza dover ricorrere a soluzioni estreme.

Con i comandi finora elencati dovreste essere in grado di cavarvela in ogni situazione. Per dare un aiuto ecco un elenco di situazioni tipiche e di possibili modi di procedere.

NOTA: i motivi che possono causare un problema sono molteplici, dall'aggiunta di un nuovo hard disk all'installazione di un nuovo sistema operativo. I casi sono esposti per sintomi, senza fare riferimento alle possibili cause.

Si vedono i drive ma non vengono caricati

Sintomi:

  • My machine came with another OS installed, I tried to install Linux/HURD/L4, and now it "won't boot at all", aka
  • My BIOS can't seem to find an OS on the drive, aka
  • GRUB non sembra trovare il bootloader.

Cause:

  • È presente un primo loader che punta in un posto errato (es. cambiato ordine degli Hard Disk);
  • Il menù è stato eliminato e/o la sua voce principale è erranea.

Soluzioni:

  • Entrare nel menù di GRUB e provare un'altra voce.
  • Boot da un LiveCD.

Carica direttamente un OS senza passare da GRUB

Sintomi:

  • Dovrei vedere il menù di GRUB, ma viene caricato direttamente l'OS.

Cause:

  • Il menù è off/soppresso?
  • È possibile che un OS di un'altra partizioni abbia (re)installato il un boatloader e per qualche ragione sovrascritto GRUB 2?

Soluzioni:

  • Provare ad entrare nel GRUB menù/shell.
  • Boot da un LiveCD.
  • Reinstallare GRUB dall'OS ripristinando il menù.

Si ferma a grub>

Sintomi:

  • Visualizzo il solo grub prompt
 Welcome to GRUB!

grub>

oppure

grub rescue>

Cause:

  • GRUB 2 non riesce a trovare il file grub.cfg.
  • Il file grub.cfg è completamente inutilizzabile.

Soluzioni:

  • cat /grub/grub.cfg. Se la parola 'title' compare da qualche parte in una "stanzas", allora qualcuno ha copiato le opzioni direttamente dal file menu.cfg di GRUB Legacy.
  • Provare dei comandi di shell per verificare come sono visualizzati i drive in GRUB 2, vedere la configurazione e trovare qualche file (immagine del kernel) che sia caricabile.

Errori del menù / "Stanza Problems"

Sintomi:

  • Si visualizza un menù ma non carica il sitema.
  • Compare un menù per alcuni secondi, prova ad eseguire il loading ma fallisce/torna al menù.
  • I briefly see some kind of complaint (such as what) and it kicks me into GRUB

Cause:

  • The more subtle items, like the caveats above.
  • Also end up here when utilities don't guess/create menu entries correctly.
  • Problemi di UUID
  • Differenze di path/drive tra ciò che è indicato nel menù e cosa invece è stato indicato al momento dell'installazione di GRUB.

Soluzione:

  • Entrare, premendo 'e' quando compare il menù, nel prompt di GRUB e cercare di identificare un sistema bootabile.

Nulla funziona

Ricorrere allora ad una live e ripristinare da lì GRUB.

Restore Windows boot-menu entry

Sometimes upgrading to grub2 removes your windows partition from the grub menu.

Follow this to get your gaming platform back: ChainLoadWindows

Ripristinare GRUB 2 da una live CD/USB

http://grub.enbug.org/Grub2LiveCdInstallGuide

Utilità

Qui seguono alcune note che possono essere di aiuto in casi particolari.

Tastiera italiana-americana

Se ci si ritrova nel prompt di grub, la configurazione della tastiera disponibile sarà quella americana. Per fortuna sono entrambe del tipo QWERTY, ma vi sono alcune differenze con gli altri caratteri. Ad esempio: (= Shift+9 )= Shift+0 = = ì - = ' _ = ?

Sitografia

Ecco alcuni link utili dove possibile reperire maggiori informazioni: