Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati
  • Differenze per "AmministrazioneSistema/RecuperoDati/Immagini"
Differenze tra le versioni 12 e 22 (in 10 versioni)
Versione 12 del 17/09/2012 11.49.59
Dimensione: 5398
Autore: f-muriana
Commento: aggiornamento a precise pangolin
Versione 22 del 05/12/2025 18.16.01
Dimensione: 9165
Autore: ivantu
Commento: +revisione_pagina; +versioni_supportate
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 4: Linea 4:
<<Indice(depth=1)>>
<<Informazioni(rilasci="12.04 10.04"; forum="http://forum.ubuntu-it.org/viewtopic.php?t=430020")>>
<<Indice(depth=2)>>
<<BR
>>
<<Informazioni(forum="http://forum.ubuntu-it.org/viewtopic.php?t=430020";rilasci="24.04 22.04 20.04 18.04 16.04 14.04")>>  
Linea 9: Linea 10:
In questo documento verrà mostrato come creare un'immagine di un dispositivo danneggiato e come estrarre i dati da essa. Questa guida illustra gli strumenti dedicati alla creazione di immagini (clonazione) di un disco rigido o di altri supporti di archiviazione danneggiati e le procedure per estrarne i dati.
Linea 11: Linea 12:
= Creare un immagine di un dispositivo = Tutti i comandi mostrati in questa guida devono essere eseguiti nel [[AmministrazioneSistema/Terminale|terminale]].
Linea 13: Linea 14:
Per ottenere l'immagine di un dispositivo danneggiato, in preparazione del salvataggio dei file, è disponibile il programma '''GNU ddrescue'''. = Creazione copia disco rigido di lavoro =
Linea 15: Linea 16:
[[AmministrazioneSistema/InstallareProgrammi|Installare]] il pacchetto [[apt://gddrescue|gddrescue]]. Prima di procedere, è fondamentale [[Hardware/DispositiviPartizioni/IndividuarePartizioni#parted|individuare]] e annotare l'identificativo, le partizioni e i file system del disco rigido da recuperare, nonché l'identificativo del disco rigido usato per il salvataggio.
Linea 17: Linea 18:
Per una breve panoramica delle sue funzionalità e per approfondimenti, si invita alla lettura del [[http://www.gnu.org/software/ddrescue/ddrescue_it.html|seguente documento]]. {{{#!wiki note
Entrambi gli strumenti seguenti per essere eseguiti richiedono una quantità di tempo più o meno cospicua, in funzione e dipendenza della dimensione del disco da recuperare e delle prestazioni del proprio computer.
}}}
Linea 19: Linea 22:
||<tablestyle="text-align: justify; width:100%; " style="border:none;" 5%><<Immagine(Icone/Piccole/note.png,,center)>> ||<style="padding:0.5em; border:none;">''Prima di proseguire, si noti che i filesystem di tipo [[http://it.wikipedia.org/wiki/File_Allocation_Table|Fat]] dispongono di un limite di 4GiB per la dimensione massima dei file. Tipicamente le unità USB utilizzano questo tipo di filesystem. Se si è a conoscenza che l'immagine finale sarà superiore a tale dimensione è necessario utilizzare dei filesystem che supportino capacità superiori per il singolo file (ad esempio, [[http://it.wikipedia.org/wiki/Ext3|Ext3]] o altri).'' || {{{#!wiki note
Prima di proseguire, si noti che i filesystem di tipo [[http://it.wikipedia.org/wiki/File_Allocation_Table|Fat]] dispongono di un limite di 4GiB per la dimensione massima dei file. Tipicamente le unità USB utilizzano questo tipo di filesystem. Se si è a conoscenza che l'immagine finale sarà superiore a tale dimensione è necessario utilizzare dei filesystem che supportino capacità superiori per il singolo file (ad esempio, [[http://it.wikipedia.org/wiki/Ext4|Ext4]] o altri).
}}}
Linea 21: Linea 26:
 * Per utilizzare '''GNU ddrescue''' digitare in una finestra di terminale un comando avente la seguente sintassi: {{{
ddrescue [options] partizione_da_recuperare destinazione_immagine destinazione_file_di_log
== Tramite dd ==

'''dd''' è uno strumento a [[AmministrazioneSistema/Terminale|riga di comando]], utilizzato per copiare e convertire file. È preinstallato in '''Ubuntu''' tramite il pacchetto [[apt://coreutils|coreutils]].

{{{#!wiki note
Per approfondire l'argomento consultare la [[#ur|pagina man]].
Linea 24: Linea 33:
 * Ad esempio il seguente comando: {{{
sudo ddrescue -r 3 /dev/sda /media/usbdrive/nome_immagine /media/usbdrive/logfile
}}}
 recupererà l'immagine dal dispositivo «dev/sda» e la salverà in «/media/usbdrive/nome_immagine». Inoltre, creerà un file di [[http://it.wikipedia.org/wiki/Log|log]] in «/media/usbdrive/logfile». L'opzione '''-r 3''' rappresenta il numero di tentativi di rilettura che ''ddrescue'' eseguirà qualora incontri degli errori. '''-1''' invita il programma ad eseguire un numero infinito di tentativi.
 * Il passo successivo potrebbe essere: {{{
sudo ddrescue -r 3 -C /dev/sda /media/usbdrive/nome_immagine /media/usbdrive/logfile
}}} dove rispetto al precedente è stata aggiunta l'opzione '''-C''' che invita il programma a circoscrivere la lettura all'interno dei file già presenti nel registro (file di log) creato in precedenza.
Linea 32: Linea 34:
Un [[http://www.forensicswiki.org/wiki/Ddrescue|noto sito]] di analisi forense consiglia la seguente procedura:
 * Creare un immagine copiando all'interno di essa più dati possibili, senza alcun tentativo di lettura nel caso si incontrino degli errori (opzione '''-n'''): {{{
sudo ddrescue -n /dev/sda /media/usbdrive/nome_immagine /media/usbdrive/logfile
Per eseguire la copia del disco, digitare il comando:{{{
sudo dd if=/dev/sdx of=/dev/sdy bs=1M status=progress
}}}Sostituire `/dev/sdx` con l'identificativo del disco sorgente e `/dev/sdy` con l'identificativo del disco di destinazione. L'opzione `status=progress` permette di visualizzare l'avanzamento della copia.

{{{#!wiki important
Il comando '''dd''' non chiede conferme. Assicurarsi che `of=` (output file) punti al dispositivo corretto, poiché i dati presenti su di esso verranno irrimediabilmente sovrascritti.
Linea 36: Linea 41:
 * Riprovare tentando 3 volte in presenza di errori di lettura: {{{
sudo ddrescue -d -r 3 /dev/sda /media/usbdrive/nome_immagine /media/usbdrive/logfile

== Tramite ddrescue ==

'''GNU ddrescue''' è uno strumento progettato per copiare dati da un file o dispositivo a blocchi (hard disk, cdrom, ecc.) a un altro, cercando di recuperare i dati in caso di errori di lettura (settori danneggiati).

{{{#!wiki note
Per una breve panoramica delle sue funzionalità e per approfondimenti, si invita alla lettura del [[http://www.gnu.org/software/ddrescue/ddrescue_it.html|seguente documento]], nonché della relativa [[#ur|pagina man]].
Linea 39: Linea 49:
 * Se il comando precedente fallisce riprovare leggendo i settori integralmente: {{{
sudo ddrescue -d -R -r 3 /dev/sda /media/usbdrive/nome_immagine /media/usbdrive/logfile

=== Installazione ddrescue ===

Se non presente o se si è su [[Installazione/CdMinimale|sistema minimale]], installare il pacchetto [[apt://gddrescue|gddrescue]].
 {{{#!wiki note
 È consigliabile creare un file immagine su un disco esterno (montato ad esempio in `/media/backup`), piuttosto che clonare direttamente disco-su-disco, per avere maggiore flessibilità.
 }}}

=== Utilizzo ===

 0. Copiare da disco a disco creando il file `log` contenente una lista spropositata degli errori trovati, digitando il comando:{{{
 ddrescue -n /dev/sdx /dev/sdy listaerrori.log
 }}}
 0. Copiare da disco a disco creando il file `log` contenente gli errori corretti, digitando il comando:{{{
 ddrescue -r 3 /dev/sdx /dev/sdy cosariparato.log
 }}}
 0. Copiare da disco a disco creando il file `log` contenente gli errori corretti, limitando la lettura all'interno dei file già listati nel file `log` precedentemente creato, digitando il comando:{{{
 ddrescue -r 3 -C /dev/sdx /dev/sdy cosariparato.log
 }}}

{{{#!wiki note
Sostituire `/dev/sdx` con l'identificativo del disco da copiare e `/dev/sdy` con l'identificativo del disco su cui copiare.
}}}

=== Procedura consigliata ===

La procedura standard prevede due passaggi: il recupero rapido delle parti sane e successivamente il tentativo di recupero dei settori danneggiati.

 0. '''Primo passaggio (recupero veloce)''': Copiare quanti più dati possibili senza tentare di recuperare i settori danneggiati, salvando un file di mappa (logfile). Digitare nel [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{
 sudo ddrescue -n /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log
 }}}Sostituire `/dev/sdx` con l'identificativo del disco sorgente.
 0. '''Secondo passaggio (recupero approfondito)''': Riprovare a leggere solo i settori che hanno dato errore nel passaggio precedente, utilizzando l'accesso diretto al disco (`-d`) e tentando la rilettura per 3 volte (`-r 3`). Digitare nel [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{
 sudo ddrescue -d -r 3 /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log
 }}}Sostituire `/dev/sdx` con l'identificativo del disco sorgente.
 0. Se il comando precedente fallisce riprovare leggendo i settori integralmente:{{{
 sudo ddrescue -d -M -r 3 /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log
 }}}

{{{#!wiki note
Il file di mappa (`mappa.log`) è essenziale, permette di interrompere e riprendere il recupero in qualsiasi momento senza ricominciare da capo.
Linea 46: Linea 94:
Dopo avere creato l'immagine del dispositivo è necessario concentrarsi sul recupero dei dati presenti sull'immagine stessa. Qualora il filesystem non è recuperabile, è possibile comunque tentare di [[AmministrazioneSistema/RecuperoDati/Estrazione|recuperare i singoli file]]. Una volta creata l'immagine del dispositivo, è possibile accedere ai dati contenuti in essa montando le partizioni virtuali.
Linea 48: Linea 96:
== Montare le partizioni sull'immagine == == Metodo automatico ==
Linea 50: Linea 98:
Se è stato recuperato l'intero disco, è possibile montare le singole partizioni utilizzando il comando: {{{
mount
}}} e le opzioni '''loop''' e '''Offset'''.
Le versioni recenti di Ubuntu permettono di associare automaticamente le partizioni contenute in un'immagine ai dispositivi di loop.
Linea 54: Linea 100:
'''mmls''', [[AmministrazioneSistema/InstallareProgrammi|installabile]] dal pacchetto [[apt://sleuthkit | sleuthkit]] è in grado di mostrare le partizioni che si trovano all'interno dell'immagine.  0. Associare l'immagine a un dispositivo loop ed eseguire la scansione delle partizioni:{{{
 sudo losetup -fP --show /media/backup/nome_immagine
 }}}Il comando restituirà il nome del dispositivo loop utilizzato, ad esempio `/dev/loop0`. Grazie all'opzione `-P`, verranno creati automaticamente i device per le partizioni (es. `/dev/loop0p1`, `/dev/loop0p2`).
 0. Montare la partizione desiderata (es. la prima partizione):{{{
 sudo mount /dev/loop0p1 /mnt
 }}}Ora i file sono accessibili nella cartella `/mnt`.
 0. Al termine delle operazioni, smontare la partizione e liberare il dispositivo loop:{{{
 sudo umount /mnt
 sudo losetup -d /dev/loop0
 }}}
Linea 56: Linea 111:
 * Digitare in una finestra di terminale il seguente comando: {{{
mmls nome_immagine -b
== Metodo manuale ==

Se il metodo automatico non dovesse funzionare, è possibile individuare manualmente l'inizio delle partizioni.

=== Individuare le partizioni nell'immagine ===

È possibile utilizzare:
 * '''fdisk'''.
 * '''mmls''' (dalla suite [[AmministrazioneSistema/RecuperoDati/Sleuthkit&Autopsy|SleuthKit]]) per leggere la tabella delle partizioni all'interno dell'immagine.

Esempio con '''mmls''', per listare le partizioni contenute nel file immagine, digitando nel [[AmministrazioneSistema/Terminale|terminale]] il seguente comando:{{{
mmls nome_immagine -B
Linea 59: Linea 124:
 * Un possibile output potrebbe essere il seguente: {{{
{{{#!wiki note
Per approfondire l'uso del programma consultare la [[#ur|pagina man]].
}}}

L'output mostrerà una tabella simile alla seguente:{{{
Linea 69: Linea 139:
}}}Annotare il settore di inizio (`Start`) e la dimensione del settore (solitamente 512 byte).

== Montare le partizioni nell'immagine ==

Per montare le singole partizioni individuate nel file immagine, occorre usare il comando '''mount''' congiuntamente alle opzioni '''loop''' e '''offset''' del comando '''losetup'''. È necessario calcolare l'offset in byte, `Start * Dimensione Settore = Offset`. Nell'esempio sopra: 32 * 512 = 16384.

Montare l'immagine specificando l'offset calcolato:{{{
sudo mount -o loop,offset=16384 nome_immagine /mnt
Linea 70: Linea 148:
 * In questo esempio, volendo montare la partizione DOS a partire dal blocco numero 32 bisognerà calcolare il numero di byte moltiplicandoli per 512 (un blocco è uguale 512 byte). In questo caso 32 * 512 = 16384 sarà il byte di inizio della partizione. Quindi montare l'immagine: {{{
sudo mount -o loop,offset=16384 nome_immagine mnt

Se si tratta di una partizione NTFS, potrebbe essere necessario specificare il tipo di filesystem:{{{
sudo mount -t ntfs -o loop,offset=32256 nome_immagine /mnt
}}}dove 32256 deriva da: blocco 63 * 512 byte.

{{{#!wiki note
Per approfondire il comando `mount` consultare la rispettiva [[#ur|pagina man]].
Linea 73: Linea 156:
 * Per montare una ipotetica partizione NTFS sarebbe possibile usare: {{{
sudo mount -t ntfs -o r,force,loop,offset=32256 file mnt
}}} dove 32256 deriva da: blocco 63 * 512 byte.
Linea 77: Linea 157:
<<Anchor(ur)>>
Linea 79: Linea 160:
 * [[http://manpages.ubuntu.com/manpages/maverick/en/man1/ddrescue.1.html|Pagina man ddrescue]]
 * [[http://www.sleuthkit.org/sleuthkit/man/mmls.html|Pagina man mmls]]
 * [[http://manpages.ubuntu.com/manpages/jammy/en/man1/dd.1.html|Pagina man dd]]
 * [[http://manpages.ubuntu.com/manpages/jammy/en/man1/ddrescue.1.html|Pagina man ddrescue]]
 * [[http://manpages.ubuntu.com/manpages/jammy/en/man8/mount.8.html|Pagina man mount]]
 * [[http://manpages.ubuntu.com/manpages/jammy/en/man8/losetup.8.html|Pagina man losetup]]
 * [[http://manpages.ubuntu.com/manpages/jammy/en/man1/mmls.1.html|Pagina man mmls]]


Guida verificata con Ubuntu: 22.04 24.04

Problemi in questa pagina? Segnalali in questa discussione

Introduzione

Questa guida illustra gli strumenti dedicati alla creazione di immagini (clonazione) di un disco rigido o di altri supporti di archiviazione danneggiati e le procedure per estrarne i dati.

Tutti i comandi mostrati in questa guida devono essere eseguiti nel terminale.

Creazione copia disco rigido di lavoro

Prima di procedere, è fondamentale individuare e annotare l'identificativo, le partizioni e i file system del disco rigido da recuperare, nonché l'identificativo del disco rigido usato per il salvataggio.

Entrambi gli strumenti seguenti per essere eseguiti richiedono una quantità di tempo più o meno cospicua, in funzione e dipendenza della dimensione del disco da recuperare e delle prestazioni del proprio computer.

Prima di proseguire, si noti che i filesystem di tipo Fat dispongono di un limite di 4GiB per la dimensione massima dei file. Tipicamente le unità USB utilizzano questo tipo di filesystem. Se si è a conoscenza che l'immagine finale sarà superiore a tale dimensione è necessario utilizzare dei filesystem che supportino capacità superiori per il singolo file (ad esempio, Ext4 o altri).

Tramite dd

dd è uno strumento a riga di comando, utilizzato per copiare e convertire file. È preinstallato in Ubuntu tramite il pacchetto coreutils.

Per approfondire l'argomento consultare la pagina man.

Per eseguire la copia del disco, digitare il comando:

sudo dd if=/dev/sdx of=/dev/sdy bs=1M status=progress

Sostituire /dev/sdx con l'identificativo del disco sorgente e /dev/sdy con l'identificativo del disco di destinazione. L'opzione status=progress permette di visualizzare l'avanzamento della copia.

Il comando dd non chiede conferme. Assicurarsi che of= (output file) punti al dispositivo corretto, poiché i dati presenti su di esso verranno irrimediabilmente sovrascritti.

Tramite ddrescue

GNU ddrescue è uno strumento progettato per copiare dati da un file o dispositivo a blocchi (hard disk, cdrom, ecc.) a un altro, cercando di recuperare i dati in caso di errori di lettura (settori danneggiati).

Per una breve panoramica delle sue funzionalità e per approfondimenti, si invita alla lettura del seguente documento, nonché della relativa pagina man.

Installazione ddrescue

Se non presente o se si è su sistema minimale, installare il pacchetto gddrescue.

    • È consigliabile creare un file immagine su un disco esterno (montato ad esempio in /media/backup), piuttosto che clonare direttamente disco-su-disco, per avere maggiore flessibilità.

Utilizzo

  1. Copiare da disco a disco creando il file log contenente una lista spropositata degli errori trovati, digitando il comando:

     ddrescue -n /dev/sdx /dev/sdy listaerrori.log
  2. Copiare da disco a disco creando il file log contenente gli errori corretti, digitando il comando:

     ddrescue -r 3 /dev/sdx /dev/sdy cosariparato.log
  3. Copiare da disco a disco creando il file log contenente gli errori corretti, limitando la lettura all'interno dei file già listati nel file log precedentemente creato, digitando il comando:

     ddrescue -r 3 -C /dev/sdx /dev/sdy cosariparato.log

Sostituire /dev/sdx con l'identificativo del disco da copiare e /dev/sdy con l'identificativo del disco su cui copiare.

Procedura consigliata

La procedura standard prevede due passaggi: il recupero rapido delle parti sane e successivamente il tentativo di recupero dei settori danneggiati.

  1. Primo passaggio (recupero veloce): Copiare quanti più dati possibili senza tentare di recuperare i settori danneggiati, salvando un file di mappa (logfile). Digitare nel terminale il seguente comando:

     sudo ddrescue -n /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log

    Sostituire /dev/sdx con l'identificativo del disco sorgente.

  2. Secondo passaggio (recupero approfondito): Riprovare a leggere solo i settori che hanno dato errore nel passaggio precedente, utilizzando l'accesso diretto al disco (-d) e tentando la rilettura per 3 volte (-r 3). Digitare nel terminale il seguente comando:

     sudo ddrescue -d -r 3 /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log

    Sostituire /dev/sdx con l'identificativo del disco sorgente.

  3. Se il comando precedente fallisce riprovare leggendo i settori integralmente:

     sudo ddrescue -d -M -r 3 /dev/sdx /media/backup/nome_immagine /media/backup/mappa.log

Il file di mappa (mappa.log) è essenziale, permette di interrompere e riprendere il recupero in qualsiasi momento senza ricominciare da capo.

Estrarre i dati da un immagine

Una volta creata l'immagine del dispositivo, è possibile accedere ai dati contenuti in essa montando le partizioni virtuali.

Metodo automatico

Le versioni recenti di Ubuntu permettono di associare automaticamente le partizioni contenute in un'immagine ai dispositivi di loop.

  1. Associare l'immagine a un dispositivo loop ed eseguire la scansione delle partizioni:

     sudo losetup -fP --show /media/backup/nome_immagine

    Il comando restituirà il nome del dispositivo loop utilizzato, ad esempio /dev/loop0. Grazie all'opzione -P, verranno creati automaticamente i device per le partizioni (es. /dev/loop0p1, /dev/loop0p2).

  2. Montare la partizione desiderata (es. la prima partizione):

     sudo mount /dev/loop0p1 /mnt

    Ora i file sono accessibili nella cartella /mnt.

  3. Al termine delle operazioni, smontare la partizione e liberare il dispositivo loop:

     sudo umount /mnt
     sudo losetup -d /dev/loop0

Metodo manuale

Se il metodo automatico non dovesse funzionare, è possibile individuare manualmente l'inizio delle partizioni.

Individuare le partizioni nell'immagine

È possibile utilizzare:

  • fdisk.

  • mmls (dalla suite SleuthKit) per leggere la tabella delle partizioni all'interno dell'immagine.

Esempio con mmls, per listare le partizioni contenute nel file immagine, digitando nel terminale il seguente comando:

mmls nome_immagine -B

Per approfondire l'uso del programma consultare la pagina man.

L'output mostrerà una tabella simile alla seguente:

DOS Partition Table
Offset Sector: 0
Units are in 512-byte sectors

     Slot    Start        End          Length       Size    Description
00:  -----   0000000000   0000000000   0000000001   0512B   Primary Table (#0)
01:  -----   0000000001   0000000031   0000000031   0015K   Unallocated
02:  00:01   0000000032   0001646591   0001646560   0803M   DOS FAT16 (0x06)
03:  00:00   0001646592   0002013183   0000366592   0179M   DOS FAT16 (0x06)

Annotare il settore di inizio (Start) e la dimensione del settore (solitamente 512 byte).

Montare le partizioni nell'immagine

Per montare le singole partizioni individuate nel file immagine, occorre usare il comando mount congiuntamente alle opzioni loop e offset del comando losetup. È necessario calcolare l'offset in byte, Start * Dimensione Settore = Offset. Nell'esempio sopra: 32 * 512 = 16384.

Montare l'immagine specificando l'offset calcolato:

sudo mount -o loop,offset=16384 nome_immagine /mnt

Se si tratta di una partizione NTFS, potrebbe essere necessario specificare il tipo di filesystem:

sudo mount -t ntfs -o loop,offset=32256 nome_immagine /mnt

dove 32256 deriva da: blocco 63 * 512 byte.

Per approfondire il comando mount consultare la rispettiva pagina man.

Ulteriori risorse


CategoryAmministrazione