Posso espandere le dimensioni di un'immagine disco basata su file?


29

Ho creato un'immagine del disco vuota usando dd, quindi ho usato mkfs per renderla una vera immagine del filesystem. Sto montando e lo sto usando bene. Ciò di cui ho bisogno è di essere in grado di espandere o ridurre questa immagine del disco basata su file quando necessario. È possibile aumentare la dimensione di un'immagine del disco in quel modo? C'è un modo per fare in modo che questa immagine disco basata su file abbia una funzione di ridimensionamento dinamico come quella che si trova nelle unità della macchina virtuale.

Risposte:


26

Per prima cosa devi creare un file immagine:

# dd if=/dev/zero of=./binary.img bs=1M count=1000
1000+0 records in
1000+0 records out
1048576000 bytes (1.0 GB) copied, 10.3739 s, 101 MB/s

Quindi, è necessario creare una partizione su di esso - è possibile utilizzare qualsiasi strumento che si desidera, fdisk, parted, gparted, preferisco parted, quindi:

# parted binary.img

Devi prima creare una tabella delle partizioni e poi una grande partizione:

(parted) mktable                                                          
New disk label type? msdos      

(parted) mkpartfs
WARNING: you are attempting to use parted to operate on (mkpartfs) a file system.
parted's file system manipulation code is not as robust as what you'll find in
dedicated, file-system-specific packages like e2fsprogs.  We recommend
you use parted only to manipulate partition tables, whenever possible.
Support for performing most operations on most types of file systems
will be removed in an upcoming release.
Partition type?  primary/extended? primary
File system type?  [ext2]? fat32
Start? 1
End? 1049M

Ora vediamo:

(parted) print
Model:  (file)
Disk /media/binary.img: 1049MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      1049kB  1049MB  1048MB  primary  fat32        lba

Sembra buona,

Vuoi ingrandirlo, quindi pugno aggiungere alcuni zeri all'immagine usando dd:

# dd if=/dev/zero bs=1M count=400 >> ./binary.img
400+0 records in
400+0 records out
419430400 bytes (419 MB) copied, 2.54333 s, 165 MB/s
root:/media# ls -al binary.img 
-rw-r--r-- 1 root root 1.4G Dec 26 06:47 binary.img

Ciò ha aggiunto 400 M all'immagine:

# parted binary.img 
GNU Parted 2.3
Using /media/binary.img
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) print                                                            
Model:  (file)
Disk /media/binary.img: 1468MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      1049kB  1049MB  1048MB  primary  fat32        lba

Come puoi vedere, la dimensione dell'immagine è diversa (1468 MB). Parted può anche mostrare spazio libero nell'immagine. Se vuoi vederlo basta digitare print freeinvece di print. Ora devi aggiungere spazio extra al filesystem:

(parted) resize 1
WARNING: you are attempting to use parted to operate on (resize) a file system.
parted's file system manipulation code is not as robust as what you'll find in
dedicated, file-system-specific packages like e2fsprogs.  We recommend
you use parted only to manipulate partition tables, whenever possible.
Support for performing most operations on most types of file systems
will be removed in an upcoming release.
Start?  [1049kB]?
End?  [1049MB]? 1468M

e controllalo:

(parted) print
Model:  (file)
Disk /media/binary.img: 1468MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      1049kB  1468MB  1467MB  primary  fat32        lba

Molto carino. Se vuoi ridurlo, fai solo una cosa simile:

(parted) resize 1
WARNING: you are attempting to use parted to operate on (resize) a file system.
parted's file system manipulation code is not as robust as what you'll find in
dedicated, file-system-specific packages like e2fsprogs.  We recommend
you use parted only to manipulate partition tables, whenever possible.
Support for performing most operations on most types of file systems
will be removed in an upcoming release.
Start?  [1049kB]?
End?  [1468MB]? 500M

Ora puoi verificare se la partizione è più piccola:

(parted) print
Model:  (file)
Disk /media/binary.img: 1468MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End    Size   Type     File system  Flags
 1      1049kB  500MB  499MB  primary  fat32        lba

Sì.

Se provi a ridimensionare la partizione quando i dati sono su di essa, devi prestare attenzione alla dimensione dei dati perché quando la riduci troppo, otterrai un errore:

Error: Unable to satisfy all constraints on the partition

Dopo aver ridotto il file system, devi anche tagliare parte del file. Ma questo è difficile. Potresti prendere il valore da parted 500M (END):

# dd if=./binary.img of=./binary.img.new bs=1M count=500

Ma questo lascia un po 'di spazio alla fine del file. Non sono sicuro del perché, ma l'immagine funziona.

E c'è una cosa nel montare tale immagine: devi conoscere un offset per passare al comando mount. È possibile ottenere l'offset, ad esempio da fdisk:

# fdisk -l binary.img

Disk binary.img: 1468 MB, 1468006400 bytes
4 heads, 32 sectors/track, 22400 cylinders, total 2867200 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x000f0321

     Device Boot      Start         End      Blocks   Id  System
binary.img1            2048     2867198     1432575+   c  W95 FAT32 (LBA)

2048 (inizio) x 512 (dimensioni del settore) = 1048576, quindi è necessario utilizzare il comando seguente per montare l'immagine:

# mount -o loop,offset=1048576 binary.img /mnt

1
Quando scrivi "Ma questo lascia un po 'di spazio alla fine del file. Non sono sicuro del perché, ma l'immagine funziona." Penso che sia causato dal fatto che stai utilizzando diverse unità di misura. In parte, hai 500 MB (in parte 1 MB è 1000 * 1000 byte), quindi 500000000 byte; in d copi 1Mx500 = 500M, dove M sta per 1024 * 1024 byte, quindi copi 524288000 byte. La differenza dovrebbe essere lo spazio che hai lasciato alla fine del file. Per risolvere, potresti fare con troncare come descritto qui softwarebakery.com/shrinking-images-on-linux o cambiare le unità di meas. in parted o in d
ste

Ora è irrilevante usare partedcon resize: "Errore: il comando di ridimensionamento è stato rimosso in parted 3.0"
Abdillah

15

Sì, questo è possibile - funziona proprio come una partizione. Ho provato quanto segue, che ha funzionato:

Crea il file originale, montalo, controlla, smonta

dd if=/dev/zero of=test.file count=102400 
mkfs.ext3 test.file 
mount test.file /m4 -o loop
df
umount /m4

Crescilo

dd if=/dev/zero count=102400 >> test.file
mount test.file /m4 -o loop
df
resize2fs /dev/loop0
df

Non vi è alcun motivo per cui la riduzione di un file non funzioni in modo simile, ma la riduzione di un file è sempre più difficile della crescita di un file (e, naturalmente, deve essere fatto quando il dispositivo a blocchi non è montato ecc.)

Dai un'occhiata a questo link che parla dell'uso di qemu-nbd per montare immagini qcow2


Fantastico, questa è esattamente la ricetta di cui avevo bisogno. Tuttavia, ho dovuto eseguire e2fsck -f test.file(sul mio file di immagine) prima di ridimensionare. Un'altra cosa: l'aggiunta di 70 G su un'immagine dell'unità memorizzata su una partizione NTFS dd ... >> drive_imagepuò richiedere circa 10 minuti.
Tomasz Gandor,

Tomasz: usa il seek=parametro param dell'altra risposta
Willem,

6

I file sparsi sono una buona scelta per le immagini dinamiche di crescita / ridimensionamento del disco.

Questo creerà un file sparse di 1024 M:

# dd if=/dev/zero of=sparse.img bs=1M count=0 seek=1024
0+0 records in
0+0 records out
0 bytes (0 B) copied, 0.000565999 s, 0.0 kB/s

L'immagine non utilizza spazio su disco,

# du -m sparse.img
0   sparse.img

ma ha le dimensioni apparenti di 1024M.

# ls -l sparse.img
-rw-rw-r--. 1 root root 1073741824 Sep 22 14:22 sparse.img

# du -m --apparent-size sparse.img
1024    sparse.img

Puoi formattarlo e montarlo come normale immagine del disco:

# parted sparse.img 
GNU Parted 2.1
Using /tmp/sparse.img
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) mktable                                                          
New disk label type? msdos                                                
(parted) mkpartfs                                                         
WARNING: you are attempting to use parted to operate on (mkpartfs) a file system.
parted's file system manipulation code is not as robust as what you'll find in
dedicated, file-system-specific packages like e2fsprogs.  We recommend
you use parted only to manipulate partition tables, whenever possible.
Support for performing most operations on most types of file systems
will be removed in an upcoming release.
Partition type?  primary/extended? primary                                
File system type?  [ext2]? fat32                                          
Start? 1                                                                  
End? 1024M                                                                
(parted) print                                                            
Model:  (file)
Disk /tmp/sparse.img: 1074MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
 1      1049kB  1024MB  1023MB  primary  fat32        lba

# du -m sparse.img 
2   sparse.img

Ora, ridimensiona usando lo stesso comando per creare semplicemente cambiando il parametro seek con la nuova dimensione dell'immagine:

dd if=/dev/zero of=sparse.img bs=1M count=0 seek=2048

Come puoi vedere, l'immagine ora è 2048 M ed è possibile ingrandire la partizione utilizzando lo strumento parted o altro a scelta.

# du -m --apparent-size sparse.img 
2048    sparse.img


# parted sparse.img 
GNU Parted 2.1
Using /tmp/sparse.img
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) print free                                                       
Model:  (file)
Disk /tmp/sparse.img: 2147MB
Sector size (logical/physical): 512B/512B
Partition Table: msdos

Number  Start   End     Size    Type     File system  Flags
        16.4kB  1049kB  1032kB           Free Space
 1      1049kB  1024MB  1023MB  primary  fat32        lba
        1024MB  2147MB  1123MB           Free Space

(parted)                               

# du -m sparse.img 
2   sparse.img

Adesso divertiti!


Ben fatto. Penso che i file sparsi siano sottoutilizzati.
TonyH,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.